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.个别同学上课不认真听讲,打开 ...
随机推荐
- 实验一:c++简单程序设计(1)
实验结论 编程练习2-28 switch版源码: #include <iostream> using namespace std; int main(void) { cout <&l ...
- 读书笔记--《编写高质量代码:改善Python程序的91个建议》
第一章 引论 建议写Pythonic式的代码,我理解为充分利用pythonAPI,用最简洁方式写出代码 1.两个变量交换: a, b = b, a 2.翻转list: a = [1, 2, 3, ...
- Sitecore8.2 Solr5.1.0配置步骤
1.首先下载Solr安装包,官方提供了几种下载,我选的的solr的5.1.0版本zip包,下载链接:http://mirror.bit.edu.cn/apache/lucene/solr. 2.下载后 ...
- CDH5.16.1集群新增节点
如果是全新安装集群的话,可以参考<Ubuntu 16.04上搭建CDH5.16.1集群> 下面是集群新增节点步骤: 1.已经存在一个集群,有两个节点 192.168.100.19 hado ...
- 博客搬家一下到CSDN
博客搬家一下到CSDN:http://blog.csdn.net/weixin_33409246
- POJ-2796 & 2019南昌邀请赛网络赛 I. 区间最大min*sum
http://poj.org/problem?id=2796 https://nanti.jisuanke.com/t/38228 背景 给定一个序列,对于任意区间,min表示区间中最小的数,sum表 ...
- 博弈论初步(SG函数)
讲解见此博客https://blog.csdn.net/strangedbly/article/details/51137432 理解Nim博弈,基于Nim博弈理解SG函数的含义和作用. 学习求解SG ...
- .NetCore WebApi 添加 Log4Net
一 .配置 1.vs2019 创建一个.net core web程序,选择webapi 2.项目中添加一个配置文件:添加--新建项--XML文件,命名为log4net.config 我使用的是log4 ...
- python 等频率切分数据
小编最近入坑风控,在工作中需要对数据进行等频率切分,也就是将数据划分成几段,在每段中,数据的出现频率,出现次数是大致相同的,让数据集在每段上呈现出分布均匀的趋势. 小编先是想到df.describe ...
- centos7与centos6命令区别
CentOS 7 vs CentOS 6的不同 (1)桌面系统[CentOS6] GNOME 2.x[CentOS7] GNOME 3.x(GNOME Shell) (2)文件系统[CentOS ...