C++ 实现冒泡排序法

 冒泡排序法

这里使用C++来实现冒泡排序法

冒泡排序法采用不停地交换彼此位置来实现,故而形象地称之为冒泡

大致一个气泡从水底一直冒到水面

一小段排序程序如下

        1、外层循环:主要是用来轮询

        2、内层循环:主要用来交换位置(前提是满足if条件)

        3、外层循环的停止条件 i < len 这应该能理解,内层循环的停止条件 j < len -i -1 来说明一下: 首先 len - 1 这个为什么要减掉 1, 因为下面 if 中有使用 buf [j+1], 所以这里要减掉1,不然 buf [j+1] 就会发生越界行为(超出了数组最大数组下标),接着看 len-i,为什么又要减掉 i 呢?因为内层循环每完成一次,最大那个值(或最小那个值),就已经交换到了最后的位置,所以下次交换的时候我们就要减少一次交换已经排序好的元素,依次类推,所以就有 len - i 这样的条件,最后合起来就是 j < len - i - 1

void sort(int *buf, int len)
{
	for (int i = 0; i < len; ++i) { // 外层循环
		for (int j = 0; j < len - i - 1; ++j) { // 内层循环
			if (buf[j] &g
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值