冒泡排序算法-C语言
冒泡排序的基本思想是通过重复遍历待排序的数列,比较相邻的元素,并将顺序错误的元素交换过来,从而把最大(或最小)的元素“冒泡”到数列的一端,就如同气泡最终会上浮到顶端一样,故名“冒泡排序”。
下面看个直接示例:
冒泡排序算法的基本步骤:
1.从第一个元素开始,比较相邻的两个元素。
2.如果第一个元素大于第二个元素,则交换它们的位置。
3.对每一对相邻元素进行同样的操作,一直到最后一个元素。这一遍下来,最大的元素会被移动到数列的最后一个位置。
4.对剩下的元素重复以上步骤,直到没有需要交换的元素为止。
代码如下:
void bubbleSort(int* arr, int len) { int swapped = 0; //交换标志 int temp = 0; //交换缓存 for (int i = 0; i < (len - 1); i++) { swapped = 0; //设置一个标志,判断是否需要提前结束排序 for (int j = 0; j < (len - 1 - i); j++) { if (arr[j] > arr[j + 1]) { //交换相邻元素 int temp = arr[j]; arr[j] = arr[j + 1]; arr[j + 1] = temp; swapped = 1; //发生了交换 } } //如果没有发生交换,说明数组已经有序,可以提前结束 if (!swapped) { break; } } }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· .NET10 - 预览版1新功能体验(一)