您的位置:首页 > 科技 > 能源 > 温州seo关键词_网络营销是怎么发展的_做任务赚佣金的正规平台_百度问答库

温州seo关键词_网络营销是怎么发展的_做任务赚佣金的正规平台_百度问答库

2025/1/18 9:29:29 来源:https://blog.csdn.net/2302_79730293/article/details/144811875  浏览:    关键词:温州seo关键词_网络营销是怎么发展的_做任务赚佣金的正规平台_百度问答库
温州seo关键词_网络营销是怎么发展的_做任务赚佣金的正规平台_百度问答库

冒泡排序

  • 基本原理
  • 步骤解析
    • 最终结果
  • 复杂度分析
  • 代码参考(C)
    • 代码分析
      • 1. 主函数:`main`
        • 代码片段
        • 功能
      • 2. 冒泡排序函数:`bubbleSort`
        • 代码片段
        • 功能
        • 具体过程
        • 关键逻辑
      • 3. 打印数组函数:`printArray`
        • 代码片段
        • 功能
        • 具体过程
  • 特点

冒泡排序(Bubble Sort)是一种简单的排序算法,其工作原理是通过多次比较相邻元素并交换位置,将较大的元素逐步“冒泡”到列表的末尾,或者较小的元素逐步“沉淀”到列表的开头。

基本原理

  1. 逐对比较:从列表的第一个元素开始,依次比较相邻的两个元素。
    • 如果前一个元素大于后一个元素,就交换它们的位置。
    • 如果前一个元素小于或等于后一个元素,则不交换。
  2. 重复过程:对每一轮的比较和交换,未排序部分的最大元素会移动到未排序部分的末尾。
  3. 减少范围:每一轮后,参与比较的范围缩小(最后一个元素不再需要参与比较)。

步骤解析

假设要对数组 [5, 3, 8, 6, 2] 进行从小到大的排序:

  1. 初始数组: [5, 3, 8, 6, 2]

  2. 第一轮排序(比较 n-1 次):

    • 比较 5 和 3,5 > 3,交换,得到 [3, 5, 8, 6, 2]
    • 比较 5 和 8,5 ≤ 8,不交换,仍是 [3, 5, 8, 6, 2]
    • 比较 8 和 6,8 > 6,交换,得到 [3, 5, 6, 8, 2]
    • 比较 8 和 2,8 > 2,交换,得到 [3, 5, 6, 2, 8]
    • 第一轮结束后,最大值 8 被“冒泡”到末尾。
  3. 第二轮排序(比较 n-2 次):

    • 比较 3 和 5,3 ≤ 5,不交换,仍是 [3, 5, 6, 2, 8]
    • 比较 5 和 6,5 ≤ 6,不交换,仍是 [3, 5, 6, 2, 8]
    • 比较 6 和 2,6 > 2,交换,得到 [3, 5, 2, 6, 8]
    • 第二轮结束后,次大值 6 被“冒泡”到倒数第二个位置。
  4. 第三轮排序(比较 n-3 次):

    • 比较 3 和 5,3 ≤ 5,不交换,仍是 [3, 5, 2, 6, 8]
    • 比较 5 和 2,5 > 2,交换,得到 [3, 2, 5, 6, 8]
    • 第三轮结束后,第三大值 5 被“冒泡”到倒数第三个位置。
  5. 第四轮排序(比较 n-4 次):

    • 比较 3 和 2,3 > 2,交换,得到 [2, 3, 5, 6, 8]
    • 第四轮结束,排序完成。

最终结果

经过 4 轮后,数组变为 [2, 3, 5, 6, 8],完成排序。


复杂度分析

  1. 时间复杂度

    • 最佳情况:O(n)(当数组已经有序,只需比较,无需交换)
    • 最坏情况:O(n²)(完全逆序,需比较和交换 n(n-1)/2 次)
    • 平均情况:O(n²)
  2. 空间复杂度:O(1)(仅使用了常量级的辅助空间)


代码参考(C)

#include <stdio.h>// 冒泡排序函数
void bubbleSort(int arr[], int n) {for (int i = 0; i < n - 1; i++) { // 外层循环:控制排序轮数int swapped = 0; // 标志位,用于优化:如果某一轮没有发生交换,则说明已排序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;swapped = 1; // 记录发生了交换}}// 如果这一轮没有交换,说明数组已经有序,直接退出if (swapped == 0) {break;}}
}// 打印数组函数
void printArray(int arr[], int n) {for (int i = 0; i < n; i++) {printf("%d ", arr[i]);}printf("\n");
}// 主函数
int main() {int arr[] = {64, 34, 25, 12, 22, 11, 90}; // 待排序数组int n = sizeof(arr) / sizeof(arr[0]);    // 计算数组长度printf("排序前的数组:\n");printArray(arr, n);bubbleSort(arr, n); // 调用冒泡排序函数printf("排序后的数组:\n");printArray(arr, n);return 0;
}

代码分析

1. 主函数:main

代码片段
int main() {int arr[] = {64, 34, 25, 12, 22, 11, 90}; // 待排序数组int n = sizeof(arr) / sizeof(arr[0]);    // 计算数组长度printf("排序前的数组:\n");printArray(arr, n);bubbleSort(arr, n); // 调用冒泡排序函数printf("排序后的数组:\n");printArray(arr, n);return 0;
}
功能

主函数是程序的入口点,负责:

  1. 定义待排序的整数数组 arr,例如:{64, 34, 25, 12, 22, 11, 90}
  2. 计算数组长度:
    • sizeof(arr) 是数组占用的总字节数。
    • sizeof(arr[0]) 是数组中单个元素占用的字节数。
    • sizeof(arr) / sizeof(arr[0]) 得到数组中元素的个数 n
  3. 打印排序前的数组内容。
  4. 调用 bubbleSort() 函数对数组进行排序。
  5. 打印排序后的数组内容。

2. 冒泡排序函数:bubbleSort

代码片段
void bubbleSort(int arr[], int n) {for (int i = 0; i < n - 1; i++) { // 外层循环:控制排序轮数int swapped = 0; // 标志位,用于优化:如果某一轮没有发生交换,则说明已排序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;swapped = 1; // 记录发生了交换}}// 如果这一轮没有交换,说明数组已经有序,直接退出if (swapped == 0) {break;}}
}
功能

对输入的数组进行升序排序,通过逐轮比较相邻元素,逐渐将较大的元素“冒泡”到数组的后端。

具体过程
  1. 外层循环

    • 循环次数为 n-1 次(for (int i = 0; i < n-1; i++)),因为每轮会将最大的未排序元素“冒泡”到最后。
    • 每轮排序后,最大的 i+1 个元素已经有序,无需参与后续比较。
  2. 标志位 swapped

    • 初始化为 0,表示当前轮次是否发生了交换。
    • 如果一轮比较结束后,swapped 仍然为 0,说明数组已经完全有序,可以提前退出外层循环,优化性能。
  3. 内层循环

    • 控制比较范围,从第一个元素到未排序部分的倒数第二个元素(j = 0j < n-i-1)。
    • 比较 arr[j]arr[j+1]
      • 如果前一个元素大于后一个元素,进行交换操作。
      • 使用 temp 变量暂存一个值,以完成交换。
  4. 提前退出

    • 如果某一轮没有发生交换,说明数组已经有序,通过 if (swapped == 0) 提前退出外层循环,节省计算时间。
关键逻辑

交换相邻元素的代码:

int temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
  • 这是经典的值交换方式,利用中间变量 temp 临时存储一个值,避免直接赋值覆盖。

3. 打印数组函数:printArray

代码片段
void printArray(int arr[], int n) {for (int i = 0; i < n; i++) {printf("%d ", arr[i]);}printf("\n");
}
功能

遍历输入的数组,并打印每个元素,用于观察数组内容在排序前后的变化。

具体过程
  1. 使用 for 循环遍历数组的每个元素(从 i = 0i < n)。
  2. 通过 printf("%d ", arr[i]) 按序打印当前元素。
  3. 在循环结束后,调用 printf("\n") 换行,以便美观地展示结果。

特点

  1. 简单易实现:适合初学者理解和实现。
  2. 稳定性:冒泡排序是稳定的,因为相等元素不会改变相对顺序。
  3. 效率较低:不适合处理大量数据,但对于小型或近乎有序的数据集,表现尚可。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com