C语言-详细讲解-冒泡排序与选择排序

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.二者区别

***新人博主创作不易,希望大家多多点赞关注呀~

相关推荐
深入理解GEE云计算8 分钟前
遥感生态指数(RSEI):理论发展、方法论争与实践进展
javascript·人工智能·算法·机器学习
渡我白衣40 分钟前
C++:链接的两难 —— ODR中的强与弱符号机制
开发语言·c++·人工智能·深度学习·网络协议·算法·机器学习
小龙报1 小时前
《算法通关指南:数据结构和算法篇 --- 顺序表相关算法题》--- 1.移动零,2.颜色分类
c语言·开发语言·数据结构·c++·算法·学习方法·visual studio
奔跑吧邓邓子1 小时前
【C语言实战(67)】从0到1:C语言多线程编程实战(POSIX线程版)
c语言·多线程编程·开发实战·posix
再睡一夏就好1 小时前
【C++闯关笔记】使用红黑树简单模拟实现map与set
java·c语言·数据结构·c++·笔记·语法·1024程序员节
im_AMBER1 小时前
Leetcode 43
笔记·学习·算法·leetcode
ceffans1 小时前
PDF文档中表格以及形状解析-后续处理(线段生成最小多边形)
c++·windows·算法·pdf
mifengxing2 小时前
力扣每日一题——接雨水
c语言·数据结构·算法·leetcode·动态规划·
魔云连洲2 小时前
前端树形结构过滤算法
前端·算法
小龙报2 小时前
《算法通关指南:数据结构和算法篇 --- 顺序表相关算法题》--- 询问学号,寄包柜,合并两个有序数组
c语言·开发语言·数据结构·c++·算法·学习方法·visual studio