补全下列直接插入排序代码 void insertSort(int data[], int length) { for (int i = 0; (1) ; i++) { int temp = data[i+1]; int j=i; while (j >-1&&temp<data[ j ]> 0) { data[j+1]=data[j]; (2) ; } data[j] = temp; } }
时间: 2024-02-14 12:21:01 浏览: 47
void insertSort(int data[], int length) {
for (int i = 0; i < length - 1; i++) {
int temp = data[i+1];
int j=i;
while (j > -1 && temp < data[j]) {
data[j+1] = data[j];
j--;
}
data[j+1] = temp;
}
}
注:代码中(1)应为 i < length - 1,(2)应为 j--。
相关问题
void insertSort(int data[], int length) { for (int i = 0; (1) ; i++) { int temp = data[i+1]; int j=i; while (j >-1&&temp<data[ j ]> 0) { data[j+1]=data[j]; (2) ; } data[j] = temp; } }补全代码
这段代码中缺少循环条件,应该是:
```
void insertSort(int data[], int length) {
for (int i = 0; i < length - 1; i++) {
int temp = data[i+1];
int j = i;
while (j >= 0 && temp < data[j]) {
data[j+1] = data[j];
j--;
}
data[j+1] = temp;
}
}
```
这是一个插入排序的实现,用于对数组 `data` 进行排序,排序的长度为 `length`。
import java.util.Arrays; public class sort { void insertSort (int r[],int n) { int i,j; for (i=2;i <=n;i++) { r[0]=r[i];j=i-1; while (r[0]<r[j]) { r[j+1]=r[j]; j=j-1; } r[j+1]=r[0]; } } public static void main(String[] args) { int array[] =new int[] {3,5,2,6,8,4}; insertSort(data,6); } }帮我改成希尔排序
好的,以下是将你提供的插入排序代码改为希尔排序的 Java 代码实现:
```
public class Sort {
void shellSort(int[] arr) {
int n = arr.length;
int gap = n / 2;
while (gap > 0) {
for (int i = gap; i < n; i++) {
int temp = arr[i];
int j = i - gap;
while (j >= 0 && arr[j] > temp) {
arr[j + gap] = arr[j];
j -= gap;
}
arr[j + gap] = temp;
}
gap /= 2;
}
}
public static void main(String[] args) {
int[] array = new int[] {3, 5, 2, 6, 8, 4};
Sort s = new Sort();
s.shellSort(array);
System.out.println(Arrays.toString(array));
}
}
```
希尔排序的核心思想是将原数组分成若干个子数组,对每个子数组进行插入排序,并不断缩小子数组的间隔,直到间隔为 1 时完成排序。代码实现中,我们使用 while 循环来进行插入排序,不断将比当前元素大的元素向后移动 gap 个位置,直到找到插入位置。需要注意的是,在插入排序过程中,我们使用的是 arr[j] > temp 而不是 arr[j] < temp,这是因为希尔排序是将数组从后往前遍历的,即从大到小排序,而插入排序是从前往后遍历的,即从小到大排序。
阅读全文