写一个插入排序 java
时间: 2023-11-03 08:03:50 浏览: 35
下面是一个简单的 Java 插入排序的实现:
```java
public class InsertionSort {
public static void main(String[] args) {
int[] arr = { 5, 2, 4, 6, 1, 3 };
insertionSort(arr);
for (int num : arr) {
System.out.print(num + " ");
}
}
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;
}
}
}
```
在上面的代码中,我们首先定义了一个 `insertionSort` 函数来实现插入排序。该函数接受一个整数数组 `arr` 作为输入参数。在函数内部,我们首先获取输入数组的长度 `n`。然后,我们从第二个元素开始遍历整个数组。对于第 `i` 个元素,我们将其保存在变量 `key` 中,并将其与前面的所有元素进行比较。如果前面的元素比 `key` 大,则将它们向右移动一位,以便为 `key` 腾出空间。最后,我们将 `key` 插入到合适的位置。通过这个过程,我们可以将整个数组排成一个有序序列。