大家好,又见面了,我是你们的朋友全栈君。
今天学了Java的数组,写了数组的插入和删除,本人小白,写给不会的小白看,大神请忽略,有错请大家指出来;
/** 给数组指定位置数组的插入 */
import java.util.*;
public class ArrayInsert{
public static void main(String []args){
System.out.println("请用键盘输入5个数:");
int [] array =new int[10];
Scanner sc=new Scanner(System.in);
//通过键盘向数组输入数
for(int i=0;i<array.length-5;i++){
array[i]=sc.nextInt();
}
//遍历数组
System.out.print("原数组为:");
for(int a:array){
System.out.print(" "+a);
}
//向指定的位置插入数
System.out.println("\n请输入插入位置:有效位置为0-----"+(array.length-1));
int index=sc.nextInt();
System.out.println("\n请输入插入的值-----");
int num=sc.nextInt();
//调用静态函数index
//遍历插入后的数组
System.out.println("插入元素之后的数组遍历:");
Insert(index,num,array);
for(int i=0;i<array.length;i++){
System.out.print(" "+array[i]);
}
}
//向数组指定位置插入数据方法
public static int[] Insert(int index,int num,int a[]){
//如果有元素,在索引之后的元素向后移一位,
for(int a[i]=a[i-1];
}
a[index]=num;
return a;
}
}
//删除数组指定位置的数字。
import java.util.*;
public class ArrayDelete{
public static void main(String args[]){
System.out.println("请用键盘输入5个数:");
int [] array =new int[10];
Scanner sc=new Scanner(System.in);
//通过键盘向数组输入数
for(int i=0;i<array.length-5;i++){
array[i]=sc.nextInt();
}
//遍历数组
System.out.print("原数组为:");
for(int a:array){
System.out.print(" "+a);
}
//删除在指定位置的数字
System.out.println("\n输入你要删除的位置: 范围在0---"+(array.length-1));
int index=sc.nextInt();
delete(index,array);//调用delete方法
//删除之后的遍历
System.out.println("删除之后的遍历:");
for(int i=0;i<array.length;i++){
System.out.print(" "+array[i]);
}
}
//数组的特性是,一旦初始化,则长度确定,所以要删除数组中元素,并且长度也随着删除而改变,则要重新建立数组
/** *删除方式1 */
public int[] delete(int index, int array[]) {
//数组的删除其实就是覆盖前一位
int[] arrNew = new int[array.length - 1];
for (int i = index; i < array.length - 1; i++) {
array[i] = array[i + 1];
}
System.arraycopy(array, 0, arrNew, 0, arrNew.length);
return arrNew;
}
/* *删除方式2 * 比如有数组 * int[] ints = {1, 2, 3}; * * @param index 注意:下标是从0开始的 * @param array 数组; * @return 删除之后的数组 */
public static int[] deleteByIndex(int index, int array[]) throws Exception {
if (index < 0 || index > array.length-1) {
throw new Exception("您输入的下标不在数组的边界内,请数组" + 0 + "到" + (array.length - 1) + "的范围");
}
//数组的删除其实就是覆盖前一位
int[] arrNew = new int[array.length - 1];
for (int i = 0; i < array.length - 1; i++) {
if (i < index) {
arrNew[i] = array[i];
} else {
arrNew[i] = array[i + 1];
}
}
return arrNew;
}
}
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/153287.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...