每日一题:冒泡排序
创始人
2024-04-18 14:53:28

每日一题:冒泡排序

  • 每日一题:冒泡排序
  • 第一种写法:
  • 第二种写法:

每日一题:冒泡排序

冒泡排序是八大排序中较为简单的一种,具体详细可见:冒泡排序_百度百科 (baidu.com)

我们重点来看冒泡排序的步骤:

冒泡排序(Bubble Sort)

算法步骤

1、比较相邻的元素。如果第一个比第二个大,就交换他们两个。

2、对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。这步做完后,最后的元素会是最大的数。

3、针对所有的元素重复以上的步骤,除了最后一个。

4、持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。

看起来有些抽象,这里我们要详细理解清楚步骤的解决方式,来看下图:

image-20221206165317665

这就是冒泡排序的思想,我们来看代码怎么实现:

第一种写法:

#includeint main()
{int arr[] = { 9,8,7,6,5,4,3,2,1 };int i = 0;int sz = sizeof(arr) / sizeof(arr[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 (i = 0; i < sz; i++){printf("%d ", arr[i]);}return 0;
}

当然了,冒泡排序也是可以用于乱序的数列的。

上面的冒泡排序是一种写法,还有一种写法与之差不多,但是有点小细节需要注意:

第二种写法:

#includeint main()
{int arr[5] = { 5 ,4 ,3 ,2 ,1 };int i = 0;int sz = sizeof(arr) / sizeof(arr[0]);//先确定一共几趟for (i = 0; i < sz - 1; i++){int j = 0;//一趟排序for (j = i+1; j < sz ; j++){if (arr[i] < arr[j]){int tmp = arr[i];arr[i] = arr[j];arr[j] = tmp;}}}for (i = 0; i < sz; i++){printf("%d,", arr[i]);}return 0;
}

上面两种方式有一些小小的需要注意的地方,我们来对比一下:

image-20221206175924099

好了,一个简单的冒泡排序今天复习一下。三天不练门外汉,勤于复习肯定是好习惯。

相关内容

热门资讯

苗族的传统节日 贵州苗族节日有... 【岜沙苗族芦笙节】岜沙,苗语叫“分送”,距从江县城7.5公里,是世界上最崇拜树木并以树为神的枪手部落...
北京的名胜古迹 北京最著名的景... 北京从元代开始,逐渐走上帝国首都的道路,先是成为大辽朝五大首都之一的南京城,随着金灭辽,金代从海陵王...
长白山自助游攻略 吉林长白山游... 昨天介绍了西坡的景点详细请看链接:一个人的旅行,据说能看到长白山天池全凭运气,您的运气如何?今日介绍...
阿西吧是什么意思 阿西吧相当于... 即使你没有受到过任何外语培训,你也懂四国语言。汉语:你好英语:Shit韩语:阿西吧(아,씨발! )日...