自定义一个可以存储 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 平时作业三的更多相关文章

  1. Java 平时作业四

    编写一个Java程序实现返回指定目录及其子目录下扩展名为*.pdf的所有文件名. 扩展: isFile public boolean isFile() 测试此抽象路径名表示的文件是否为普通文件. 如果 ...

  2. Java 平时作业七

    以下是几本计算机书籍的基本信息 编号  书名         价格      出版社 1  JAVA 基础   32   清华大学出版社 2  JAVA WEB 开发  40   电子工业出版社 3  ...

  3. Java 平时作业六

    编写一个 Java 应用程序,使用 Java 的输入输出流技术将 Input.txt 的内容(Input.txt 为文本 文件)逐行读出, 每读出一行就顺序为其添加行号(从 1 开始,逐行递增),并写 ...

  4. Java 平时作业五

    使用 I/O 流和文件对象实现目录备份功能. package asg5; import java.io.File; import java.io.FileInputStream; import jav ...

  5. JAVA 平时作业二

    编写一个 Java 应用程序,统计数组{1,3,4,7,2,1,1,5,2,5,7,2,1,1,3},统 计显示每种数字其出现的次数以及出现最多和最少次数的数字 public class Number ...

  6. JAVA 平时作业一

    public class Print { public static void main (String arg[]) { for(int i=0;i<16;i++) { for(int j=0 ...

  7. 2017-2018-1 JAVA实验站 第三周作业

    2017-2018-1 JAVA实验站 第三周作业 团队展示 队名 JAVA实验站 拟作的团队项目描述 (2048)增加其他模式,使得2048更加丰富多彩 团队的首次合照 团队的特色描述 团队内部很团 ...

  8. JAVA作业三

    (一)学习总结 1.阅读下面程序,分析是否能编译通过?如果不能,说明原因.应该如何修改?程序的运行结果是什么?为什么子类的构造方法在运行之前,必须调用父 类的构造方法?能不能反过来? class Gr ...

  9. 对于“2017面向对象程序设计(Java)第三周学习总结”存在问题的反馈

    对于“2017面向对象程序设计(Java)第三周学习总结”存在问题的反馈 一:教学中存在的学习问题 “1.由于同学们平时练习不足,上课总是出现跟不上老师的节奏的现象. 2.个别同学上课不认真听讲,打开 ...

随机推荐

  1. 剑指offer 14:链表中倒数第k个节点

    题目描述 输入一个链表,输出该链表中倒数第k个结点. /* public class ListNode { int val; ListNode next = null; ListNode(int va ...

  2. 使用MySQL workbench 和Excel表之间的数据互相导出

    导出数据是很常用的功能,但今天在操作时遇到了一点问题,记录下来,方便其他人查阅. 1. 使用MySQL workbench 导出数据 在workbench里连接好数据库之后直接点击左侧的managem ...

  3. linux 修改普通用户的 max user process

    因为出现  fork: retry: No child processes 问题 , google了一下 , 大家说是要去修改 /etc/security/limits.conf 文件 , 然后我用r ...

  4. js对象跟数组多层嵌套,检测没有此数据就添加有则不添加以及超过限制条件删除操作

    例如你需要这样格式的数据: [{"name":"合肥市","arrey":[{"lat":"31.862323 ...

  5. Java /C# 实现文件压缩

    纯粹为了记录. 参考了 https://www.cnblogs.com/zeng1994/p/7862288.html import java.util.List; import java.util. ...

  6. 亚马逊VE账号运营

    VE劲爆内幕大揭秘!“仿牌+Amazon VE”跟卖之路 Amazon Vendor Express 是Amazon.com2015年下旬推出的新的供应商平台,商家通过这个平台可以把产品卖给Amazo ...

  7. cowboy源码分析(三)

    上接 cowboy源码分析(二) 我们接着分析cowboy_protocol.erl的request/7模块 -module(cowboy_protocol). %% API.-export([sta ...

  8. JMETER-01

    jmter安装 1.Linxu安装: 步骤:下载JMeter包-->解压包-->赋权限-->配置环境变量-->测试服务 1.下载:wget http://mirrors.hus ...

  9. MySQL 8 配置文件

    包括功能: 端口,是否启用bin log , 指定目录, InnoDB是否启用压缩,MySQL使用旧的密码验证方式. 说明,建表的时候要添加必要的参数才会启用表数据压缩存储,以下为例: CREATE ...

  10. Vue.js错误: Maximum call stack size exceeded

    这几天正自学Vue, 用eggjs + vue 采用前后分离,写一个网站练练手. 增加了一个商品详情页 Detail.vue的时候,点击进入Detail.vue的时候,页面显示空白,打开浏览器调试工具 ...