第一篇记录:冒泡排序

在学习C语言的过程中,我初次接触冒泡排序,最初对其双层循环的必要性感到困惑。通过实践和深入理解,我意识到冒泡排序的精髓在于逐步稳定排序。本文记录了这一过程,分享了自己编写冒泡排序代码的心得,以及养成良好编程习惯的重要性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

12月6号去了工作室迎新,和师兄交流了一下,师兄现在在做一个游戏一边写着博客记录过程,他和我说了一些写博客的好处,当时没怎么在意因为这么多年来我都不是一个喜欢记录东西的人,可是今天在看c语言的视频学习的时候看到了冒泡排序,暂停看了一下代码,竟然弄不明白为什么要两重循环,不是交换了就会排好了吗?后来再看视频继续讲才知道原因,还是自己不够细心没有亲自试过的缘故,所以自己又重新写了一下,自己写的时候果然会有很多感悟。也是今天才知道养成好的风格的重要~刚改的风格应该还算标准吧?

#include<stdio.h>
int main()
{
int i, j, temp;
int a[10] = {1, 22, 55, 77 , 89, 96, 74, -8, 99, -11};   // 给需要排序的数组赋值
printf("排列前为:");
for(i = 0; i < 9; ++i){
printf("%d ", a[i]);
}
for(i = 0; i < 9; ++i){  //这是一个大循环,意义是执行9次找出最大值并让它排列好,因为第一个不用排所以是9次
for(j = 0; j < 9; ++j){ //这是一个小的循环,它的作用是两两比较,选出其中较大排在后面,其中较小在前面。第一次结束的时候并不是就排列好了 ,只是选出一个整个数组中最大的值放在最后。
if(a[j] > a[j+1]){
temp = a[j];
a[j] = a[j+1];
a[j+1] = temp;
}
}
}
printf("\n排列后为:");
for(i = 0; i <= 9; ++i){
printf("%d ",a[i]);
}
printf("\n");
return 0;
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值