C语言————冒泡排序(例题2)

冒泡排序 的核心思想:两两相邻的元素进行比较将较大或最小的元素逐步"冒泡"到序列的末尾 ,一趟冒泡排序的目标是完成一次从头到尾的遍历,最终可将任意一组数据 排成升序 或着降序

我们以升序为例,先来理解一下冒泡的过程:

比如,给定一个元素个数为 10 的数组,我们来分析一下怎么个冒泡排序法:10个元素的话要比较9 轮,依次将最大的元素移动到最后面的位置上。每一轮相邻两个元素进行逐步比较,10个元素每轮逐级递减,比较 ( 10 - 1 - i ) 次。

cs 复制代码
#include <stdio.h>
//升序
void paixu(int arr[],int sz)
{
	int i = 0;
    //轮数
	for (i = 0; i < sz-1; i++)
	{
		int j = 0;
        //一轮排序的过程
		for (j = 0; j < sz - 1 - i; j++)
		{
			if (arr[j] > arr[j + 1])
			{
				int tmp = arr[j];
				arr[j] = arr[j + 1];
				arr[j + 1] = tmp;
			}
		}
	}
	for (int i = 0; i < sz; i++)
	{
		printf("%d ",arr[i]);
	}
}
int main()
{
	int arr[10] = { 9,3,5,4,1,7,2,6,8,0 };
	int sz = sizeof(arr) / sizeof(arr[0]);
	paixu(arr,sz);
	return 0;
}

运行结果:

大家一定要理解冒泡排序这个过程,但是会遇到这么一种情况:如果一组数据中只有一个元素比较突兀,其他元素都是正常按照升序排列的,那么这个时候,只需要走一轮即可,但是该段代码并不会比较一轮后停下来。针对这种情况,我们只需要对代码进行稍作修改。

这时,只要我们设置一个变量就可以了。

看到这里,你是否对冒泡排序感到清晰明了了,赶快动手试一试吧。加油!!

这里小博送上自己喜欢的一句话给大家,"夏虫不可语冰,井蛙不可语海,曲士不可语道"。

相关推荐
JAVA面经实录9171 小时前
Java 数据结构与算法 (终极完整学习文档)
java·数据结构·算法
开源Z3 小时前
LeetCode 42 · 接雨水:从暴力到双指针的三步优化
算法·leetcode
旖-旎3 小时前
《LeetCode 695 岛屿的最大面积 FloodFill DFS 解法》
c++·算法·力扣·深度优先遍历·floodfill
影视飓风TIM3 小时前
数据结构 | 链表超全笔记(单链表+双链表+高频算法题)
数据结构·笔记·链表
syagain_zsx4 小时前
STL 之 vector 讲练结合
c++·算法
十月的皮皮4 小时前
C语言学习笔记20260615-有序升序序列合并
c语言·笔记·学习
牛油果子哥q4 小时前
STL set与map底层精讲,红黑树适配原理、有序去重特性、迭代器遍历、API实战与面试核心考点全解
开发语言·数据结构·c++·面试
MartinYeung55 小时前
[论文学习]DP2Unlearning:高效且具保证的大型语言模型遗忘框架(基于差分隐私的 LLM Unlearning 方法)
学习·算法·语言模型
Tian_Hang5 小时前
C++原型模式(Protype)
开发语言·c++·算法