用Java写一个直接插入排序算法
时间: 2024-05-04 12:22:24 浏览: 13
好的,以下是Java代码实现直接插入排序算法:
```
public class InsertionSort {
public static void main(String[] args) {
int[] arr = {5, 2, 8, 3, 9, 1};
insertionSort(arr);
System.out.println(Arrays.toString(arr));
}
public static void insertionSort(int[] arr) {
int n = arr.length;
for (int i = 1; i < n; i++) {
int key = arr[i];
int j = i - 1;
while (j >= 0 && arr[j] > key) {
arr[j + 1] = arr[j];
j--;
}
arr[j + 1] = key;
}
}
}
```
这段代码中,首先定义了一个 `main` 方法来测试 `insertionSort` 方法。在 `insertionSort` 方法中,我们从第二个元素开始遍历数组,将当前元素 `key` 存储在一个变量中。然后,我们使用另一个变量 `j` 来遍历已经排序好的子数组。如果子数组中的元素比 `key` 大,则将它们向右移动一位。最后,将 `key` 插入到正确的位置。这样,通过遍历整个数组,我们可以将其排序。