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