c语言插入排序的代码例子
时间: 2023-05-31 15:01:49 浏览: 96
以下是一个简单的C语言插入排序示例:
```c
void insertionSort(int arr[], int n)
{
int i, key, j;
for (i = 1; i < n; i++) {
key = arr[i];
j = i - 1;
/*将所有大于key的元素向右移动*/
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]);
insertionSort(arr, n);
for (int i = 0; i < n; i++)
printf("%d ", arr[i]);
return 0;
}
```
这段代码使用了插入排序算法将整数数组排序,通过将元素向右移动来插入元素,最终得到一个按升序排列的数组。
相关问题
C语言折半插入排序代码
在C语言中,折半插入排序是一种改进的插入排序算法,它通过每次将数组分成两部分,对每一部分分别进行排序,然后合并,以此减少比较次数,提高效率。以下是简单的折半插入排序的实现代码:
```c
#include <stdio.h>
void swap(int* a, int* b) {
int temp = *a;
*a = *b;
*b = temp;
}
int partition(int arr[], int low, int high) {
int pivot = arr[high];
int i = (low - 1);
for (int j = low; j <= high - 1; j++) {
if (arr[j] <= pivot) {
i++;
swap(&arr[i], &arr[j]);
}
}
swap(&arr[i + 1], &arr[high]);
return (i + 1);
}
void insertionSortRecursive(int arr[], int low, int high) {
if (low < high) {
int pi = partition(arr, low, high);
insertionSortRecursive(arr, low, pi - 1);
insertionSortRecursive(arr, pi + 1, high);
}
}
void halfInsertionSort(int arr[], int n) {
insertionSortRecursive(arr, 0, n / 2);
insertionSortRecursive(arr + n / 2, n / 2, n - 1);
}
int main() {
int arr[] = {9, 7, 5, 11, 12, 2, 14, 3};
int n = sizeof(arr) / sizeof(arr[0]);
printf("Original array:\n");
for (int i=0; i < n; i++)
printf("%d ", arr[i]);
halfInsertionSort(arr, n);
printf("\nSorted array using Half Insertion Sort:\n");
for (int i=0; i < n; i++)
printf("%d ", arr[i]);
return 0;
}
```
在这个例子中,`halfInsertionSort`函数首先对数组的前半部分进行排序,再对后半部分进行排序。`partition`函数用于将数组分为两个部分并找到基准元素的位置。
C语言直接插入排序代码
C语言中的直接插入排序是一种简单直观的排序算法,它的工作原理是通过遍历未排序部分,将每个元素插入到已排序部分的正确位置。以下是C语言实现直接插入排序的示例代码:
```c
#include <stdio.h>
void insertion_sort(int arr[], int n) {
int i, key, j;
for (i = 1; i < n; i++) { // 从第二个元素开始
key = arr[i]; // 保存当前元素
j = i - 1;
/* 将大于key的元素向右移动 */
while (j >= 0 && arr[j] > key) {
arr[j + 1] = arr[j];
j = j - 1;
}
arr[j + 1] = key; // 插入到正确的位置
}
}
int main() {
int data[] = {5, 2, 4, 6, 1, 3};
int size = sizeof(data) / sizeof(data[0]);
printf("Original array: \n");
for (int i = 0; i < size; i++)
printf("%d ", data[i]);
printf("\n");
insertion_sort(data, size);
printf("Sorted array: \n");
for (int i = 0; i < size; i++)
printf("%d ", data[i]);
printf("\n");
return 0;
}
```
在这个例子中,`insertion_sort()`函数接收一个整数数组和它的大小作为参数。函数内部通过逐个比较并交换元素的过程实现了排序。在`main()`函数中,我们创建了一个数组,并展示了排序前后的样子。
阅读全文