用java代码编写一个直接插入排序算法
时间: 2023-04-09 15:00:45 浏览: 79
好的,以下是用Java编写的直接插入排序算法:
```
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 = j - 1;
}
arr[j + 1] = key;
}
}
```
这个算法的时间复杂度为O(n^2),适用于小规模的数据排序。
相关问题
用Java写一个直接插入排序算法
好的,以下是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` 插入到正确的位置。这样,通过遍历整个数组,我们可以将其排序。
用C语言数据结构编写程序实现直接插入排序算法
好的,以下是用C语言实现直接插入排序算法的示例代码:
```c
#include <stdio.h>
void insertionSort(int arr[], int n) {
int i, key, j;
for (i = 1; i < n; i++) {
key = arr[i];
j = i - 1;
while (j >= 0 && arr[j] > key) {
arr[j + 1] = arr[j];
j = j - 1;
}
arr[j + 1] = key;
}
}
int main() {
int arr[] = { 12, 11, 13, 5, 6 };
int n = sizeof(arr) / sizeof(arr[0]);
int i;
printf("Before sorting:\n");
for (i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
printf("\n");
insertionSort(arr, n);
printf("After sorting:\n");
for (i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
printf("\n");
return 0;
}
```
在这个示例中,我们定义了一个名为 `insertionSort` 的函数,接受一个整数数组和数组的大小作为参数,然后使用直接插入排序算法对数组进行排序。主函数中我们定义了一个整数数组 `arr`,并将其作为参数传递给 `insertionSort` 函数以进行排序。排序完成后,我们使用循环打印已排序的数组。
希望这个示例能够帮助你理解直接插入排序算法的实现方式。