思路:
查找数字就是用循环挨个比较。
删除数字就是用该数字后的每位数字往前覆盖,最后再总长-1.
代码主体:
import java.util.Scanner;
public class shuzushan {
//数组中查找并删除任意数字
public static void main(String[] args) {
//定义数组
int[] a = {1, 8, 9, 4, 6, 10};
//定义变量(保险起见x取了负数)
int i, x = -1;
for (int i1 = 0; i1 < 6; i1++) {
System.out.print(" " + a[i1]);
}
System.out.println();
System.out.println("输入你要查找的数字:");
Scanner scanner = new Scanner(System.in);
//将输入的值赋给i1
int i1 = scanner.nextInt();
//用for循环挨个与数组中的数字比对
for (i = 0; i < 6; i++) {
//如果找到相等的就停止查找
if (i1 == a[i]) {
//取得该数字的"座位号"赋给x
x = i;
//输出
System.out.println("找到了,是第" + (i + 1) + "个数字");
//跳出该循环
break;
}
}
//因为i只有在没找到的情况下才能等于6,所以作为没找到的条件判断
if (i == 6) {
//输出
System.out.println("没找到");
}
//只有在找到相等的数字时,x才能等于i,所以作为判断条件
if (x == i) {
//这个循环开始删数据
//删除数据就是从该数字后往前一个一个覆盖,并且总长-1
//因为没有数据覆盖最后一个数据,所以覆盖次数是总长-1
for (int b = x; b < a.length - 1; b++) {
a[b] = a[b + 1];
}
//输出
System.out.println("删除成功");
for (int b = 0; b < a.length - 1; b++) {
System.out.print(" " + a[b]);
}
}
}
}
输出结果:
能找到的情况下:
1 8 9 4 6 10
输入你要查找的数字:
9
找到了,是第3个数字
删除成功
1 8 4 6 10
Process finished with exit code 0
找不到的情况下:
1 8 9 4 6 10
输入你要查找的数字:
11
没找到
Process finished with exit code 0
原文链接: https://blog.csdn.net/daibadetianshi/article/details/136766109