1.冒泡排序
- 冒泡排序是一种比较简单的排序算法。它重复地走访要排序的数列,一次比较两个元素,如果它们的顺序错误就把它们交换过来。走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。
- 这个名字的由来是因为越小(或越大)的元素会经由交换慢慢 "浮" 到数列的顶端(或底端),就像气泡在水中上浮一样。
(这里以对5个数的排序为例)
cpp
#include <stdio.h>
int main() {
int arr[5];
printf("Enter No. 1:");
scanf("%d", &arr[0]);
printf("Enter No. 2:");
scanf("%d", &arr[1]);
printf("Enter No. 3:");
scanf("%d", &arr[2]);
printf("Enter No. 4:");
scanf("%d", &arr[3]);
printf("Enter No. 5:");
scanf("%d", &arr[4]);
for (int i = 0; i < 5 - 1; i++) {
for (int j = 0; j < 5 - i - 1; j++) {
if (arr[j] > arr[j + 1]) {
int temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
for (int i = 0; i < 5; i++) {
printf("%d", arr[i]);
}
return 0;
}
2.选择排序
- 选择排序的基本思想是首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾。以此类推,直到所有元素均排序完毕。
(这里以对5个数的排序为例)
cpp
#include <stdio.h>
// 交换两个数的函数
void swap(int *a, int *b) {
int temp = *a;
*a = *b;
*b = temp;
}
// 选择排序函数
void selectionSort(int arr[], int n) {
int i, j, min_idx;
for (i = 0; i < n - 1; i++) {
min_idx = i;
for (j = i + 1; j < n; j++)
if (arr[j] < arr[min_idx])
min_idx = j;
// 交换找到的最小元素和当前位置的元素
swap(&arr[min_idx], &arr[i]);
}
}
int main() {
int arr[5];
// 输入5个数
for (int i = 0; i < 5; i++) {
printf("Enter No.%2d:", i + 1);
scanf("%d", &arr[i]);
}
// 调用选择排序函数
selectionSort(arr, 5);
// 输出排序后的数
for (int i = 0; i < 5; i++) {
printf("%d", arr[i]);
}
return 0;
}
3.二者区别
***新人博主创作不易,希望大家多多点赞关注呀~