请用c++写一个排序算法
时间: 2023-08-31 16:42:35 浏览: 67
### 回答1:
可以用冒泡排序算法,它的原理是比较相邻的元素,如果第一个比第二个大,就交换他们两个,然后持续比较相邻的元素,直到没有再需要交换,排序完成。C语言实现的冒泡排序算法如下:void bubble_sort(int array[], int n)
{
int i, j, temp;
for (i = 0; i < n; i++)
{
for (j = 0; j < n - i - 1; j++)
{
if (array[j] > array[j + 1])
{
temp = array[j];
array[j] = array[j + 1];
array[j + 1] = temp;
}
}
}
}
### 回答2:
C语言可以用多种排序算法实现,其中比较常用且简单的有冒泡排序、插入排序和选择排序。这里以冒泡排序为例:
冒泡排序(Bubble Sort)是一种简单的排序算法,它通过比较相邻元素并交换它们的位置来实现排序。在每一轮比较过程中,将较大的元素逐渐“冒泡”到数组的末尾。下面是用C语言实现冒泡排序的代码:
```c
#include <stdio.h>
void bubbleSort(int arr[], int size) {
int i, j;
for (i = 0; i < size - 1; i++) { // 控制比较的轮数
for (j = 0; j < size - i - 1; j++) { // 每轮比较的次数
if (arr[j] > arr[j + 1]) { // 比较相邻元素的大小
// 交换位置
int temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
}
int main() {
int arr[] = {64, 34, 25, 12, 22, 11, 90};
int size = sizeof(arr) / sizeof(arr[0]);
bubbleSort(arr, size);
printf("排序后的数组:");
for (int i = 0; i < size; i++) {
printf("%d ", arr[i]);
}
return 0;
}
```
以上代码使用了双重循环实现了冒泡排序算法。首先外层循环`i`控制了总共需要进行比较的轮数,内层循环`j`表示每一轮比较的次数。在每一轮比较中,通过比较相邻元素的大小来判断是否需要交换位置。经过`size-1`轮的比较后,数组中的元素就被排序成升序。最后,程序输出排序后的数组。
冒泡排序是一种简单但效率较低的算法,当排序的元素数量较多时,其时间复杂度为O(n^2)。如果需要更高效的排序算法,可以考虑使用更加复杂的快速排序、归并排序等其他排序算法。
### 回答3:
C语言中常见的排序算法有冒泡排序、选择排序、插入排序、快速排序等。下面以快速排序为例进行实现。
快速排序的基本思路是通过一趟排序将待排记录分割成独立的两个部分,其中一部分记录的关键字均小于另一部分的关键字,然后分别对这两部分继续进行排序,以达到整个序列有序的目的。
以下是对整型数组arr进行快速排序的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[low]; // 将第一个元素作为基准元素
while (low < high) {
while (low < high && arr[high] >= pivot) {
high--;
}
swap(&arr[low], &arr[high]); // 将比基准小的元素交换到低端
while (low < high && arr[low] <= pivot) {
low++;
}
swap(&arr[low], &arr[high]); // 将比基准大的元素交换到高端
}
return low; // 返回基准元素位置
}
void quickSort(int arr[], int low, int high) {
if (low < high) {
int pivotPos = partition(arr, low, high); // 划分数组
quickSort(arr, low, pivotPos - 1); // 递归排序基准元素左边的子数组
quickSort(arr, pivotPos + 1, high); // 递归排序基准元素右边的子数组
}
}
int main() {
int arr[] = {5, 3, 8, 4, 2, 1, 9, 6, 7};
int len = sizeof(arr) / sizeof(arr[0]);
quickSort(arr, 0, len - 1);
for (int i = 0; i < len; i++) {
printf("%d ", arr[i]);
}
return 0;
}
```
以上代码实现了快速排序算法,通过不断选择一个基准元素,并将比基准小的元素交换到低端,将比基准大的元素交换到高端,最终将数组划分为两个部分,在递归调用时对子数组进行排序,直到待排序的序列长度为1。最后输出排序结果。
运行结果为:1 2 3 4 5 6 7 8 9。表示数组已按升序排列。