Bag类课后作业
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类课后作业的更多相关文章
- String字符串类课后作业
String动手动脑和课后作业 请运行以下示例代码StringPool.java,查看其输出结果.如何解释这样的输出结果?从中你能总结出什么? 结果: 总结:在Java中,内容相同的字串常量(&quo ...
- 课堂作业-Bag类的实现
课堂作业-Bag类的实现 要求: 代码运行在命令行中,路径要体现学号信息,IDEA中,伪代码要体现个人学号信息 参见Bag的UML图,用Java继承BagInterface实现泛型类Bag,并对方法进 ...
- 20162320刘先润第三周Bag类测试
前言 以下内容是本周Bag代码的课后作业,要求是完成伪代码.产品代码和测试代码,为了书写方便我将伪代码以注释的形式写在了产品代码的后面 测试步骤 1.首先对Bag类引用BagInterface的代码进 ...
- java课后作业
课后作业之字串加密: 设计思想: 1.输入要加密的英文子串str 2.定义num=str的字符串长度 3.将字符串转化为单个字符 4.每个字符+3,向后移3个 5.定义str1,将新得到的每个字符加到 ...
- Bag类的接口的实现与测试(课上测试补做)
Bag类的接口的实现与测试(课上测试补做) 截图 由于截图有一定的的限制就没有吧所有的代码截进去,后面有代码. 代码 package ClassTest; import java.util.Objec ...
- java课后作业-5
作业一:请写一个类,在任何时候都可以向它查询“你已经创建了多少个对象?“ 程序源代码; public class Lei { /** * @param args */ public static vo ...
- Java字符串课后作业
[实验任务] 1.实验题目:字串加密 2.实验内容:古罗马皇帝凯撒在打仗时曾经使用过以下方法加密军事情报:
- C++第三章课后作业答案及解析---指针的使用
今天继续完成上周没有完成的习题---C++第三章课后作业,本章题涉及指针的使用,有指向对象的指针做函数参数,对象的引用以及友元类的使用方法等 它们具体的使用方法在下面的题目中会有具体的解析(解析标注在 ...
- JAVA第三周课后作业
JAVA课后作业 一.枚举类型 代码: enum Size{SMALL,MEDIUM,LARGE}; public cl ass EnumTest { public static void main( ...
随机推荐
- ASP.NET Core 如何实现404错误跳转到主页
假如用户在Web浏览器上敲错了URL,访问了ASP.NET Core站点下一个不存在的URL地址,那么默认情况下ASP.NET Core会返回给浏览器著名的404错误,那么有什么办法可以让ASP.NE ...
- Redis全方位详解--数据类型使用场景和redis分布式锁的正确姿势
一.Redis数据类型 1.string string是Redis的最基本数据类型,一个key对应一个value,每个value最大可存储512M.string一半用来存图片或者序列化的数据. 2.h ...
- python3安装crypto出错,及解决方法
首先我用的python3.5的版本 问题的由来,我想通过python去实现RSA加密算法时,破解某网站的js加密认证,网上说需要安装pycrypto,我就去进行pip安装了 pip install p ...
- 用NI的数据采集卡实现简单电子测试之6——数字I/O及测试平台
本文从本人的163博客搬迁至此. 前面几个例子介绍了NI数据采集卡的模拟输入和输出功能,本例则集中介绍USB-6009的数字输入输出功能.本例包括基本数字IO电路及在LabVIEW中控制USB-600 ...
- 20155238 2016-2017-2 《Java程序设计》第一周学习总结
教材内容总结 浏览教材,根据自己的理解每章提出一个问题 1.Java语言跨平台的依据是什么?标准的出现是否会限制JAVA的开发与发展? 2.怎样理解类?PATH对于Java编写的意义是什么? 3.Ja ...
- msfconsole 无法启动,解决办法
今天突然碰上kali msfconsole 无法启动,经过查找资料,现已成功解决该问题,现将解决办法整理如下: service postgresql start # 启动数据库服务 msfdb ini ...
- LOJ #6089. 小 Y 的背包计数问题
LOJ #6089. 小 Y 的背包计数问题 神仙题啊orz. 首先把数分成\(<=\sqrt n\)的和\(>\sqrt n\)的两部分. \(>\sqrt n\)的部分因为最多选 ...
- CentOS7中使用阿里云镜像
之前因为下载Docker镜像很慢所以用了一家国内的镜像DaoCloud,今天要用的是阿里云的镜像库. 首先要开通了阿里云开发者帐号,地址 : https://dev.aliyun.com/search ...
- 【PaPaPa】实现缓存决策 - 让你的缓存变的有智慧
我有话说 本来这一篇我打算放到后面再说,可是之前泄漏了一点关于缓存决策的代码后被好多人催更了. 在此感谢大家的支持,让我更有动力的写这个系列.你们的关注让我觉得我的决定是对的,我会坚持下去把这个项目做 ...
- 【总结】详细说说Html.ActionLink的用法
Html.ActionLink概述 在MVC的Rasor视图引擎中,微软采用一种全新的方式来表示从前的超链接方式,它代替了从前的繁杂的超链接标签,让代码看起来更加简洁,通过浏览器依然会解析成传统的a标 ...