我正在尝试按排序顺序将元素添加到一个数组中。
这是我的代码:
```` ```python ``` ````
我得到的输出是: [5, 6, 9, 11, 0, 0]
[5, 6, 7, 9, 9, 9]
但正确的输出应该是:
5,6,9,11,0,0
5,6,7,9,11,0
这是我的代码:
```` ```python ``` ````
public class SortedInsertion {
public static void main(String[] args) {
int[] arr=new int[6];
arr[0]=5;
arr[1]=6;
arr[2]=9;
arr[3]=11;
System.out.println(Arrays.toString(arr));
insert(7,arr);
}
public static void insert(int val,int[] arr){
int i;
for(i=0;i<arr.length-1;i++){
if(arr[i]>val)
break;
}
for(int k=i;k<arr.length-1;k++){
arr[k+1]=arr[k];
arr[i]=val;
}
System.out.println(Arrays.toString(arr));
}
}
我得到的输出是: [5, 6, 9, 11, 0, 0]
[5, 6, 7, 9, 9, 9]
但正确的输出应该是:
5,6,9,11,0,0
5,6,7,9,11,0
arr[k+1]=arr[k]; arr[i]=val
会被执行多次(在循环中),因此导致了输出结果。 - TheLostMindSystem.arraycopy
来移动尾部并腾出空间。这样更快更清晰。 - Boris the SpiderSystem.arraycopy
实现的解决方案。 - Kaplan