20162316 Bag课后作业

下面小标题都是码云链接

import java.util.Arrays;

public class Bag implements BagInterface {
Object[] stuff = new Object[0]; @Override
public int getCurrentSize() {
int size = 0;
for(int a = 0; a<stuff.length;a++){
if(stuff[a] != null) size++;
}
return size;
} @Override
public boolean isEmpty() {
boolean a = false;
if (getCurrentSize() ==0)
a = true; return a;
} //初始的包上限为0,每次在添加新的条目前将其上限加一,成为一个哆啦A梦的四次元口袋。
@Override
public boolean add(Object newEntry) {
boolean b = false;
stuff = Arrays.copyOf(stuff, stuff.length+1);
for (int a = 0;a < stuff.length;a++){
if (stuff[a] == null){
stuff[a] = (Object) newEntry;
b = true;
break;
}
}
return b;
} @Override
public Object remove() {
int a = (int)Math.random() * ( getCurrentSize());
Object removed = stuff[a];
stuff[a] = null;
return removed;
} @Override
public boolean remove(Object anEntry) {
boolean b = false;
for (int a = 0;a < stuff.length;a++){
if (stuff[a].equals(anEntry)){
b = true;
stuff[a] = null;
break;
}
}
return b;
} @Override
public void clear() {
for (int a = 0;a < stuff.length;a++){
stuff[a] = null;
}
} @Override
public int getFrequencyOf(Object anEntry) {
int num = 0;
for (int a = 0;a < stuff.length;a++){
if (stuff[a].equals(anEntry))
num++;
}
return num;
} @Override
public boolean contains(Object anEntry) {
boolean b = false;
for (int a = 0;a < stuff.length;a++){
if (stuff[a].equals(anEntry))
b =true;
break;
}
return b;
} @Override
public Object toArray() {
int num = 0;
Object [] BAG = new Object[getCurrentSize()];
for(Object element:stuff){
BAG[num] = element;
num++;
}
return BAG;
}
}
import junit.framework.TestCase;

public class BagTest extends TestCase {
Bag bag = new Bag(); public void testGetCurrentSize1() throws Exception {
bag.add(1);
assertEquals(1, bag.getCurrentSize());
} public void testIsEmpty1() throws Exception {
bag.add(123);
assertEquals(false, bag.isEmpty());
} public void testAdd1() throws Exception {
assertEquals(true, bag.add(1));
} public void testRemove2() throws Exception {
bag.add(523);
System.out.println(bag.remove());
} public void testRemove3() throws Exception {
bag.add(30);
assertEquals(true, bag.remove(30));
} public void testClear1() throws Exception {
bag.add(99);
bag.clear();
assertEquals(0,bag.getCurrentSize());
} public void testGetFrequencyOf1() throws Exception {
bag.add(111);
bag.add(222);
bag.add(111);
assertEquals(2,bag.getFrequencyOf(111)); } public void testContains1() throws Exception {
bag.add(75);
assertEquals(true,bag.contains(75));
} public void testToArray1() throws Exception {
bag.add(951);
System.out.println(bag.toArray());
}

Bag类课后作业的更多相关文章

  1. String字符串类课后作业

    String动手动脑和课后作业 请运行以下示例代码StringPool.java,查看其输出结果.如何解释这样的输出结果?从中你能总结出什么? 结果: 总结:在Java中,内容相同的字串常量(&quo ...

  2. 课堂作业-Bag类的实现

    课堂作业-Bag类的实现 要求: 代码运行在命令行中,路径要体现学号信息,IDEA中,伪代码要体现个人学号信息 参见Bag的UML图,用Java继承BagInterface实现泛型类Bag,并对方法进 ...

  3. 20162320刘先润第三周Bag类测试

    前言 以下内容是本周Bag代码的课后作业,要求是完成伪代码.产品代码和测试代码,为了书写方便我将伪代码以注释的形式写在了产品代码的后面 测试步骤 1.首先对Bag类引用BagInterface的代码进 ...

  4. java课后作业

    课后作业之字串加密: 设计思想: 1.输入要加密的英文子串str 2.定义num=str的字符串长度 3.将字符串转化为单个字符 4.每个字符+3,向后移3个 5.定义str1,将新得到的每个字符加到 ...

  5. Bag类的接口的实现与测试(课上测试补做)

    Bag类的接口的实现与测试(课上测试补做) 截图 由于截图有一定的的限制就没有吧所有的代码截进去,后面有代码. 代码 package ClassTest; import java.util.Objec ...

  6. java课后作业-5

    作业一:请写一个类,在任何时候都可以向它查询“你已经创建了多少个对象?“ 程序源代码; public class Lei { /** * @param args */ public static vo ...

  7. Java字符串课后作业

    [实验任务] 1.实验题目:字串加密 2.实验内容:古罗马皇帝凯撒在打仗时曾经使用过以下方法加密军事情报:

  8. C++第三章课后作业答案及解析---指针的使用

    今天继续完成上周没有完成的习题---C++第三章课后作业,本章题涉及指针的使用,有指向对象的指针做函数参数,对象的引用以及友元类的使用方法等 它们具体的使用方法在下面的题目中会有具体的解析(解析标注在 ...

  9. JAVA第三周课后作业

    JAVA课后作业 一.枚举类型 代码: enum Size{SMALL,MEDIUM,LARGE}; public cl ass EnumTest { public static void main( ...

随机推荐

  1. (oralce)pga_aggregate_target与workarea_size_policy相互关系验证

    pga_aggregate_target与workarea_size_policy相互关系验证 先放上结论: 1. 当pga_aggregate_target设置为非0, 手工设置(workarea ...

  2. 小程序canvas中文字设置居中锚点

    小程序中经常会遇到要生成图片的需求,图片一般会加上用户的头像和昵称之类的,头像只需要把腾讯域名添加到request和download列表中,使用wx.getImageInfo()就可以缓存到本地,成功 ...

  3. ruby的循环使用及区别(for、each等)

    ruby的循环有以下几种: times方法 for语句 while语句 until语句(与while相反) each方法(与for极度相似,在ruby内部,for语句是用each实现的) loop方法 ...

  4. Scala_单例对象

    在 Scala 中,是没有 static 这个东西的,但是它也为我们提供了单例模式的实现方法,那就是使用关键字 object. 对象的无参构造器在第一次使用时被调用,且单例对象没有有残构造器. Enu ...

  5. Nodejs-第一篇(什么是NodeJS)

    NodeJS 介绍 Node.js 是什么? 1.Node.js 是一个开发平台,就像Java开发平台..Net开发平台.PHP开发平台.Apple开发平台一样: 什么是开发平台?它们有对应的编程语言 ...

  6. mybatis第二天_拓展——与spring整合以及逆向工程

    一.整合思路 1.SqlSessionFactory对象应该放到spring容器中作为单例存在. 2.传统dao的开发方式中,应该从spring容器中获得sqlsession对象. 3.Mapper代 ...

  7. 20155237 2016-2017-2 《Java程序设计》第9周学习总结

    20155237 2016-2017-2 <Java程序设计>第9周学习总结 教材学习内容总结 第十六章 整合数据库 JDBC入门 驱动的四种类型 JDBC-ODBC Bridge Dri ...

  8. shiro配置说明

    Shiro主要是通过URL过滤来进行安全管理,这里的配置便是指定具体授权规则定义. Xml代码   <bean id="shiroFilter" class="or ...

  9. django学习笔记(2)

    Part 2: The admin site ====> Creating an admin user$ python manage.py createsuperuser   Username: ...

  10. 【HNOI2011】卡农

    题面 题解 将无序化为有序,最后答案除以$m!$. 设$f[i]$表示选出了$i$个子集,并且满足所有的限制的方案数. 因为转移困难,所以考虑容斥 限制了每个数的出现次数为偶数,所以如果前$i - 1 ...