每日一题——冒泡排序

2024-06-23 1628阅读

C语言——冒泡排序

  • 冒泡排序
  • 练习

    每日一题——冒泡排序

    前言:CSDN的小伙伴们,大家好!今天我来给大家分享一种解题思想——冒泡排序。

    冒泡排序

    1. 冒泡法的核心思想:两两相邻的元素进行比较

      2.冒泡排序的算法描述如下。

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

    (2)对每一对相邻元素做同样的工作,从开始第一对到结尾的最后 一对。在这一点,最后的元素应该会是最大的数。

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

    (4)持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。以6个数9、8、5、4、2、0为例:

    第1趟比较,有6个数未排好序,两两比较5次;

    第2趟比较,剩5个数未排好序,两两比较4次;

    第3趟比较,剩4个数未排好序,两两比较3次;

    第4趟比较,剩3个数未排好序,两两比较2次;

    第5趟比较,剩2个数未排好序,两两比较1次;

    第6趟比较,全部排好序,两两比较0次。

    结论:对于n个数的排序,需进行n-1趟比较,第j次比较,需进行n-j次比较

    冒泡排序不单指从小到大,也可以从大到小。对于冒泡排序,或许我们大家都比较熟悉,就比如说,对成绩进行排名,游戏排行榜,等等。这样都可以使用冒泡排序的思想,对数据进行排序。

    练习

    输人10个数,对10个数排序(由小到大)。

    //1
    #include
    int main()
    {
    	int a[10] = { 10 };
    	int i = 0;
    	int j = 0;
    	int t = 0;
    	for (i = 0; i  a[i + 1])
    			{
    				t = a[i];
    				a[i] = a[i + 1];
    				a[i + 1] = t;
    			}
    		}
    	}
    	for (i = 0; i  arr[j + 1])
    			{
    				int t = arr[j];
    				arr[j] = arr[j + 1];
    				arr[j + 1] = t;
    			}
    		}
    	}
    }
    void print_arr(int arr[], int sz)
    {
    	int i = 0;
    	
    	for (i = 0; i  arr[j + 1])
    			{
    				int t = arr[j];
    				arr[j] = arr[j + 1];
    				arr[j + 1] = t;
    				flag = 0;
    			}
    		}
    		if (flag = 1)
    		{
    			break;
    		}
    	}
    }
    void print_arr(int arr[], int sz)
    {
    	int i = 0;
    	for (i = 0; i  
    

    (完)

    点个关注再走吧!

VPS购买请点击我

免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

目录[+]