C语言零基础笔记16–冒泡排序详解

数组作为函数参数:

往往在我们写代码的时候,我们会将数组作为参数传个函数,比如我们要实现一个冒泡排序函数将一个整形数组排序:

(1)现在进行冒泡排序的思想学习📑

要实现升序,冒泡排序思想上两两相邻的元素进行比较。89fb71a631b047ad95fb3597b458b2f5.png

⬆️这个为一趟冒泡排序

紧接着我们需要排序9,👇也是一趟冒泡排序!!!

61190e0dc26343cfb5fb2434350cdae2.png 

(2)如何编写代码?

1、确定冒泡的趟数(10个元素有9趟,所以n个元素有n-1趟)

e50fdd9574f54ceda435bc1b6156383c.png 

2、每一趟冒泡排序指定元素和相邻元素进行大小比较,确定其位置。

例子🌰:10个元素里面

第一趟冒泡排序元素10,一趟里面排了9次,

第二趟冒泡排序排元素9,一趟里面排了8次,

如果说排序元素 :元素个数-1-趟数fc13f311a1c6439cbb7f695f4658f59a.png

3、输出部分需要在主函数中再次遍历

f5b3b0d1163f43eb8c1c431aa42d2ab6.png

总代码⚠️

016219f2becb4564aeb3bc709b20009f.png 重点⚠️:arr是数组,我们对数组arr进行传参,实际上传递过去的是数组arr 的首元素的地址。

(3)但是我们的数组如果是0,1,2,3,4,5升序排列,这样的做法会很复杂,因此我们需要优化我们的代码。

我们可以设置flag=1来假设这一趟的排序数据已经有序。

那么自定义函数如下👇

842c3671676947e5868834934cb698ee.png

如果是降序排列

5e5e85d6404d4cc78b137bd8f40bc334.png

1、 sizeof(数组名),计算整个数组的大小,sizeof内部单独放一个数组名,数组名表示整个数组。

2、&数组名,取出的是数组地址。&数组名,数组名表示整个数组。

除了上述两种情况,所有的数组名都表示数组的手元素地址。

 

下一篇:实现三子棋游戏

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小奶盖儿月月

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值