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 quickSort(int arr[], int low, int high) { if (low < high) { // 划分分区,并获取基准元素的索引 int pi = partition(arr, low, high); // 对基准元素左右两边的子数组进行递归排序 quickSort(arr, low, pi - 1); quickSort(arr, pi + 1, high); } } // 打印数组元素 void printArray(int arr[], int size) { for (int i = 0; i < size; i++) { printf("%d ", arr[i]); } printf("\n"); } int main() { int arr[] = {12, 5, 7, 3, 9, 2, 14}; int size = sizeof(arr) / sizeof(arr[0]); printf("原始数组: "); printArray(arr, size); quickSort(arr, 0, size - 1); printf("排序后数组: "); printArray(arr, size); return 0; }

这是一个基本的快速排序实现,通过递归方式对数组进行排序。在这个例子中,选择数组的最右边元素作为基准元素,然后进行分区操作。随着分区的进行,小于基准的元素被移到基准的左边,大于基准的元素被移到右边。递归地对左右两个子数组进行相同的操作,最终完成整个排序过程。

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 quickSort(int arr[], int low, int high) { if (low < high) { // 找到分割点 int pi = partition(arr, low, high); // 分别对分割点的左右两部分递归进行排序 quickSort(arr, low, pi - 1); quickSort(arr, pi + 1, high); } } // 打印数组 void printArray(int arr[], int size) { for (int i = 0; i < size; i++) { printf("%d ", arr[i]); } printf("\n"); } // 主函数 int main() { int arr[] = {64, 25, 12, 22, 11}; int n = sizeof(arr) / sizeof(arr[0]); printf("原始数组:\n"); printArray(arr, n); // 调用快速排序函数 quickSort(arr, 0, n - 1); printf("排序后的数组:\n"); printArray(arr, n); return 0; }

这个代码演示了快速排序的基本思想,通过选择一个基准值并将数组中的元素重新排列,使得基准值左边的元素都小于基准值,右边的元素都大于基准值。然后递归地对左右两部分进行相同的操作,最终完成整个排序过程。