【难】. 完成一个方法,删除指定下标的元素,要求从删除位置开始,之后的元素整体前移。【难】
[1,2,3,4,5,6,7]=>[1,2,4,5,6,7,0]
【难】. 完成一个方法,添加指定元素到指定下标位置,要求从指定下标位置之后的元素,整体向后移动。【难】
[1,2,3,4,5,0]=>[1,2,250,3,4,5]
【难】. 找出数组中最大的元素,放到下标为0的位置
public static void main(String[] args) {
work1(); // [1,2,3,4,5,6,7] => [1,2,4,5,6,7,0]
work2(); // {1,2,3,4,5,0} => {1,2,250,3,4,5}
work3(); // 找到 最大值放到0位置上
}
private static void work3() {// 第三题
int [] arr = {11,12,13,14,20,19,18,17,16};
// 假设第一个数的值最大
int index = 0;
for (int i = 1; i < arr.length; i++) {
int max = arr[index];
if (max < arr[i]){
index = i; // 如果i位置的数大于max就把i的值付给index
}
}
System.out.println(arr[index]);
arr[0] = arr[index];
System.out.println(Arrays.toString(arr));
}
private static void work2() {// 第二题
int [] arr = {1,2,3,4,5,0};
int [] arr1 = new int[arr.length];
int index = 2;
int num = 250;
System.arraycopy(arr,0,arr1,0,index); // 实现数组的拷贝功能,参数的含义分别是:(从arr数组中的0下标开始拷贝,拷贝到arr1中从0开始输入,从arr中拿取index长度个元素。)
System.out.println(Arrays.toString(arr1));
arr1[index] = num;
System.arraycopy(arr,index,arr1,index+1,arr.length-index-1);
System.out.println(Arrays.toString(arr1));
}
private static void work1() { // 第一题
int arr [] = {1,2,3,4,5,6,7};
int rm = 2;
int arr1 [] = new int[arr.length];
System.arraycopy(arr,0,arr1,0,rm);
System.out.println(Arrays.toString(arr1));
System.arraycopy(arr,rm+1,arr1,rm,arr.length-rm-1);
System.out.println(Arrays.toString(arr1));
}