Java 平时作业三
自定义一个可以存储 int 类型的集合类(例如:SequenceList),封装一维数组存储数据,该 集合类具有以下方法:
(1)新增元素;
(2)在指定位置插入一个元素;
(3)按位置删除元素;
(4)按值删除元素
(5)排序(增序,降序)
(6)查询指定元素,返回下标位置。
import java.util.Scanner; public class SequenceList { public static void main(String[] args) {
int a[] = { 1,5,4,6,8,3,4,0 };
int key;
int elem,index;
String c;
boolean flag=true;
Scanner sc = new Scanner(System.in);
IntUtil test = new IntUtil(a); out: while(flag) {
System.out.println("请输入相关选项:");
System.out.println("(1)新增元素");
System.out.println("(2)在指定位置插入一个元素");
System.out.println("(3)按位置删除元素;");
System.out.println("(4)按值删除元素 ");
System.out.println("(5)排序(增序)");
System.out.println("(6)排序(降序)");
System.out.println("(7)查询指定元素,返回下标位置");
System.out.println("(0)退出");
key = sc.nextInt();
switch(key) {
case 1:
System.out.println("请输入要添加的元素");
elem=sc.nextInt();
test.addElement(elem);
break;
case 2:
System.out.println("请输入添加的元素及位置");
elem=sc.nextInt();
index=sc.nextInt();
test.addElementAtIndexOf(elem, index);
break;
case 3:
System.out.println("请输入要删除元素的位置");
index=sc.nextInt();
test.deleteElementAtIndexOf(index);
break;
case 4:
System.out.println("请输入要删除的元素的值");
elem=sc.nextInt();
test.deleteElement(elem);
break;
case 5:
test.arraySortUp();
break;
case 6:
test.arraySortDown();
break;
case 7:
System.out.println("请输入要查找的元素");
elem=sc.nextInt();
test.searchElement(elem);
break;
case 0:
flag=false;
System.out.println("程序已结束");
break out;
default:
System.out.println("没有该选项,请重新输入");
continue;
}
System.out.println("是否继续?y/n");
c=sc.next();
if(c.equals("n"))
{ flag=false;
System.out.println("程序已结束");
}
if(c.equals("y"))
flag=true;
} } } class IntUtil {
int array[]; public IntUtil(int a[]) {
super();
array = a;
} public void arraySortDown() {
// TODO Auto-generated method stub for (int i = 0; i < array.length; i++) {
for (int j = i + 1; j < array.length; j++) {
if (array[i] < array[j]) {
int temp = array[i];
array[i] = array[j];
array[j] = temp;
}
}
}
show();
} public void arraySortUp() {
// TODO Auto-generated method stub
for (int i = 0; i < array.length; i++) {
for (int j = i + 1; j < array.length; j++) {
if (array[i] > array[j]) {
int temp = array[i];
array[i] = array[j];
array[j] = temp;
}
}
}
show();
} void addElement(int a) {
int[] newArray = new int[array.length + 1]; for (int i = 0; i < array.length; i++) {
newArray[i] = array[i];
} newArray[array.length] = a; array = newArray; show();
} void addElementAtIndexOf(int a, int index) {
index=index-1;
int[] newArray = new int[array.length + 1]; for (int i = 0; i < index; i++) {
newArray[i] = array[i];
} newArray[index] = a; for (int i = index + 1; i < array.length; i++) {
newArray[i] = array[i - 1];
}
newArray[array.length] = array[array.length - 1];
array = newArray;
show();
} void deleteElementAtIndexOf(int index) {
int[] newArray = new int[array.length - 1]; for (int i = 0; i < index - 1; i++) {
newArray[i] = array[i];
} for (int i = index; i < array.length; i++) {
newArray[i - 1] = array[i];
}
array = newArray;
show();
} void deleteElement(int a) {
for (int i = 0; i < array.length; i++) {
if (a == array[i]) {
deleteElementAtIndexOf(i + 1);
}
} } int elementAt(int a) {
return 0;
} int searchElement(int a) {
for(int i=0;i<array.length;i++)
{
if(array[i]==a)
{ System.out.println("该数的下标为"+i);
return 0;
} }
System.out.print("该数不存在");
return 0;
} void show() {
for (int i = 0; i < array.length; i++) {
System.out.print(array[i]+" ");
}
System.out.println();
}
}
Java 平时作业三的更多相关文章
- Java 平时作业四
编写一个Java程序实现返回指定目录及其子目录下扩展名为*.pdf的所有文件名. 扩展: isFile public boolean isFile() 测试此抽象路径名表示的文件是否为普通文件. 如果 ...
- Java 平时作业七
以下是几本计算机书籍的基本信息 编号 书名 价格 出版社 1 JAVA 基础 32 清华大学出版社 2 JAVA WEB 开发 40 电子工业出版社 3 ...
- Java 平时作业六
编写一个 Java 应用程序,使用 Java 的输入输出流技术将 Input.txt 的内容(Input.txt 为文本 文件)逐行读出, 每读出一行就顺序为其添加行号(从 1 开始,逐行递增),并写 ...
- Java 平时作业五
使用 I/O 流和文件对象实现目录备份功能. package asg5; import java.io.File; import java.io.FileInputStream; import jav ...
- JAVA 平时作业二
编写一个 Java 应用程序,统计数组{1,3,4,7,2,1,1,5,2,5,7,2,1,1,3},统 计显示每种数字其出现的次数以及出现最多和最少次数的数字 public class Number ...
- JAVA 平时作业一
public class Print { public static void main (String arg[]) { for(int i=0;i<16;i++) { for(int j=0 ...
- 2017-2018-1 JAVA实验站 第三周作业
2017-2018-1 JAVA实验站 第三周作业 团队展示 队名 JAVA实验站 拟作的团队项目描述 (2048)增加其他模式,使得2048更加丰富多彩 团队的首次合照 团队的特色描述 团队内部很团 ...
- JAVA作业三
(一)学习总结 1.阅读下面程序,分析是否能编译通过?如果不能,说明原因.应该如何修改?程序的运行结果是什么?为什么子类的构造方法在运行之前,必须调用父 类的构造方法?能不能反过来? class Gr ...
- 对于“2017面向对象程序设计(Java)第三周学习总结”存在问题的反馈
对于“2017面向对象程序设计(Java)第三周学习总结”存在问题的反馈 一:教学中存在的学习问题 “1.由于同学们平时练习不足,上课总是出现跟不上老师的节奏的现象. 2.个别同学上课不认真听讲,打开 ...
随机推荐
- redis 执行操作时提示(error) NOAUTH Authentication required.
(error) NOAUTH Authentication required. 出现认证问题,设置了认证密码,输入密码即可 127.0.0.1:6379> auth 123456
- Python三大神器:装饰器,迭代器,生成器
一.装饰器 由于一个函数能实现一种功能,现在想要在不改变其代码的情况下,让这个函数进化一下,即能保持原来的功能,还能有新的"技能",怎么办? 现已经存在一个自定义的函数func1, ...
- curl 向远程服务器传输file文件
public function upload(){ //获取上传文件信息,文件名称以自己实际上传文件名称为准 $fileinfo = $_FILE['filename']; //请求参数,依据商户自己 ...
- 远程和Ubuntu服务器进行Socket通信,使用python和C#(准备篇)
服务器在阿里云上,和一般的本地配置方案不太一样,所以网上的博客里没有解决办法,本人在这里记录一下,方便大家交流. 由于数据要保存到MySQL数据库中,使用python对数据进行操作,爬到数据直接进行保 ...
- hdoj4859海岸线
1.地图周围再加一圈海 2.周长最多为sum=n*(m+1)+m*(n+1).如果有邻接相同,要减1.最小割使相同最少.结果为sum-最小割 3.但是有E海滩,两边都能选.让E到S,T都连一个很大的数 ...
- Python --判断路径是否为目录或文件
os.path.isdir( ), os.path.isfile(),os.listdir( ), os.walk( ) 参考网址:https://blog.csdn.net/xxn_723911/a ...
- 使用 jquery.wordexport.js导出的Word排版
js导出word文档所需要的两个插件: FileSaver.js jquery.wordexport.js 使用jquery.wordexport.js这个插件导出的word文档的排版方式: 编辑器打 ...
- css选择器以及使用场景
1.选择器以及使用场景 id选择器:#header{} 类选择器:.header{} 元素选择器:div{} 子选择器:ul > li{} 后代选择器:div p{} 伪类选择器:a:hover ...
- Sublime Text3安装evernote插件
关键字 Markdown编辑器.Evernote.Sublime Text3 正文 Sublime Text3安装evernote插件方法如下: 1.使用Package Control安装ever ...
- 箭头函数里this理解
先来看代码: var obj1={ id:4, fn:function(){ var f=() => { console.log(this); //object,f()定义在obj1对象中,th ...