news 2026/2/8 8:26:41

嵌入式C语言阶段复习——排序方法

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
嵌入式C语言阶段复习——排序方法

一、冒泡排序

冒泡排序通过重复比较相邻元素并交换位置完成排序。每一轮将最大(或最小)元素“冒泡”到数组

末尾。

void bubbleSort(int arr[], int n) { for (int i = 0; i < n - 1; i++) { for (int j = 0; j < n - i - 1; j++) { if (arr[j] > arr[j + 1]) { int temp = arr[j]; arr[j] = arr[j + 1]; arr[j + 1] = temp; } } } }

时间复杂度:平均和最坏情况为 O(n^2),最好情况(已排序)为 O(n)。

二、选择排序

选择排序每次遍历未排序部分,找到最小(或最大)元素,与未排序部分的起始位置交换。

void selectionSort(int arr[], int n) { for (int i = 0; i < n - 1; i++) { int min_idx = i; for (int j = i + 1; j < n; j++) { if (arr[j] < arr[min_idx]) { min_idx = j; } } int temp = arr[min_idx]; arr[min_idx] = arr[i]; arr[i] = temp; } }

时间复杂度:始终为 O(n^2)

三、插入排序

插入排序将数组分为已排序和未排序两部分,逐个将未排序元素插入到已排序部分的正确位置。

void insertionSort(int arr[], int n) { for (int i = 1; i < n; i++) { int key = arr[i]; int j = i - 1; while (j >= 0 && arr[j] > key) { arr[j + 1] = arr[j]; j--; } arr[j + 1] = key; } }

时间复杂度:平均和最坏为 O(n^2),最好情况(已排序)为 O(n)

四、快速排序

快速排序采用分治策略,选择一个基准值(pivot),将数组分为小于基准和大于基准的两部分,递

归排序子数组。
实现代码:

int partition(int arr[], int low, int high) { int pivot = arr[high]; int i = low - 1; for (int j = low; j < high; j++) { if (arr[j] < pivot) { i++; int temp = arr[i]; arr[i] = arr[j]; arr[j] = temp; } } int temp = arr[i + 1]; arr[i + 1] = arr[high]; arr[high] = temp; 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); } }

时间复杂度:平均为 O(n *log n),最坏(已排序或逆序)为 O(n^2)

五、归并排序

归并排序通过递归将数组分为两半,分别排序后合并。

void merge(int arr[], int l, int m, int r) { int n1 = m - l + 1; int n2 = r - m; int L[n1], R[n2]; for (int i = 0; i < n1; i++) L[i] = arr[l + i]; for (int j = 0; j < n2; j++) R[j] = arr[m + 1 + j]; int i = 0, j = 0, k = l; while (i < n1 && j < n2) { if (L[i] <= R[j]) arr[k++] = L[i++]; else arr[k++] = R[j++]; } while (i < n1) arr[k++] = L[i++]; while (j < n2) arr[k++] = R[j++]; } void mergeSort(int arr[], int l, int r) { if (l < r) { int m = l + (r - l) / 2; mergeSort(arr, l, m); mergeSort(arr, m + 1, r); merge(arr, l, m, r); } }

时间复杂度:始终为 O(n *log n),但需要额外空间 O(n)。

六、堆排序

堆排序利用堆数据结构(完全二叉树),通过构建最大堆并交换堆顶元素实现排序。

void heapify(int arr[], int n, int i) { int largest = i; int left = 2 * i + 1; int right = 2 * i + 2; if (left < n && arr[left] > arr[largest]) largest = left; if (right < n && arr[right] > arr[largest]) largest = right; if (largest != i) { int temp = arr[i]; arr[i] = arr[largest]; arr[largest] = temp; heapify(arr, n, largest); } } void heapSort(int arr[], int n) { for (int i = n / 2 - 1; i >= 0; i--) heapify(arr, n, i); for (int i = n - 1; i > 0; i--) { int temp = arr[0]; arr[0] = arr[i]; arr[i] = temp; heapify(arr, i, 0); } }

时间复杂度:始终为 O(n *log n)

七、总结

简单排序:冒泡、选择、插入排序适合小规模数据。

高效排序:快速、归并、堆排序适合大规模数据,快速排序通常最快。

稳定性:插入、归并排序是稳定的(相等元素顺序不变)。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/6 10:48:20

day70(1.29)——leetcode面试经典150

210. 课程表 II 210. 课程表Ⅱ 这题跟之前那题一样&#xff01;&#xff01;&#xff01; 题目&#xff1a; 题解&#xff1a; class Solution {public int[] findOrder(int numCourses, int[][] prerequisites) {//创建记录先修课程int[] pres new int[numCourses];//创建…

作者头像 李华
网站建设 2026/2/8 12:21:13

部署Z-Image-Turbo踩坑记录,这些问题你可能也会遇到

部署Z-Image-Turbo踩坑记录&#xff0c;这些问题你可能也会遇到 1. 为什么选Z-Image-Turbo&#xff1f;不是所有“快”都一样 第一次看到“Z-Image-Turbo”这个名字时&#xff0c;我下意识以为又是个营销噱头——毕竟现在叫“Turbo”“Ultra”“Pro Max”的模型太多了。直到我…

作者头像 李华
网站建设 2026/2/7 18:56:47

当企业面对智能化转型,如何借助AI销冠系统提升数字员工的工作表现?

数字员工在当前智能化转型的过程中扮演着越来越重要的角色。他们通过AI销冠系统得以优化业务流程&#xff0c;使企业能够在竞争激烈的市场环境中保持高效和灵活。数字员工利用这一系统的智能功能&#xff0c;能够在客户沟通、数据处理和市场分析方面实现显著提升。他们能够快速…

作者头像 李华
网站建设 2026/2/5 4:47:37

黑芝麻智能与萝卜快跑达成战略合作,共同打造无人驾驶生态圈

1月29日&#xff0c;黑芝麻智能与百度旗下萝卜快跑正式签署战略合作协议。黑芝麻智能作为萝卜快跑合作范围内产品研发的算力芯片技术支撑单位&#xff0c;全力配合萝卜快跑产品的相关技术研究及成果转化&#xff1b;萝卜快跑在方案验证等方面为黑芝麻智能提供指导、支持。双方将…

作者头像 李华
网站建设 2026/2/6 18:21:42

自媒体人必备!Qwen-Image-Edit快速生成社交媒体配图技巧

自媒体人必备&#xff01;Qwen-Image-Edit快速生成社交媒体配图技巧 你是不是也经历过这些时刻&#xff1a; 凌晨两点赶稿&#xff0c;突然发现缺一张应景的封面图&#xff1b; 临时接到选题&#xff0c;要为“夏日露营”配图&#xff0c;但手头只有张室内自拍&#xff1b; 发…

作者头像 李华