冒泡法排序

网上有关“冒泡法排序”话题很是火热,小编也是针对冒泡法排序寻找了一些与之相关的一些信息进行分析 ,如果能碰巧解决你现在面临的问题,希望能够帮助到您。

冒泡法排序如下:

冒泡法排序它重复地走访过要排序的元素列,依次比较两个相邻的元素 ,如果顺序(如从大到小、首字母从Z到A)错误就把他们交换过来 。走访元素的工作是重复地进行,直到没有相邻元素需要交换,也就是说该元素列已经排序完成。

这个算法的名字由来是因为越小的元素会经由交换慢慢“浮”到数列的顶端(升序或降序排列) ,就如同碳酸饮料中二氧化碳的气泡最终会上浮到顶端一样,故名“冒泡排序 ”。

冒泡排序就是把小的元素往前调或者把大的元素往后调 。比较是相邻的两个元素比较,交换也发生在这两个元素之间。

所以 ,如果两个元素相等,是不会再交换的;如果两个相等的元素没有相邻,那么即使通过前面的两两交换把两个相邻起来 ,这时候也不会交换 ,所以相同元素的前后顺序并没有改变,所以冒泡排序是一种稳定排序算法。

算法原理:

1、比较相邻的元素 。如果第一个比第二个大,就交换他们两个。对每一对相邻元素做同样的工作 ,从开始第一对到结尾的最后一对。在这一点,最后的元素应该会是最大的数 。

2 、针对所有的元素重复以上的步骤,除了最后一个。持续每次对越来越少的元素重复上面的步骤 ,直到没有任何一对数字需要比较。

C语言冒泡排序法是什么?

原理是临近的数字两两进行比较,按照从小到大或者从大到小的顺序进行交换,\x0d\这样一趟过去后,最大或最小的数字被交换到了最后一位,\x0d\然后再从头开始进行两两比较交换,直到倒数第二位时结束,其余类似看例子\x0d\例子为从小到大排序,\x0d\原始待排序数组| 6 | 2 | 4 | 1 | 5 | 9 |\x0d\第一趟排序(外循环)\x0d\第一次两两比较6 > 2交换(内循环)\x0d\交换前状态| 6 | 2 | 4 | 1 | 5 | 9 |\x0d\交换后状态| 2 | 6 | 4 | 1 | 5 | 9 |\x0d\ \x0d\第二次两两比较,6 > 4交换\x0d\交换前状态| 2 | 6 | 4 | 1 | 5 | 9 |\x0d\交换后状态| 2 | 4 | 6 | 1 | 5 | 9 |\x0d\第三次两两比较,6 > 1交换\x0d\交换前状态| 2 | 4 | 6 | 1 | 5 | 9 |\x0d\交换后状态| 2 | 4 | 1 | 6 | 5 | 9 |\x0d\第四次两两比较,6 > 5交换\x0d\交换前状态| 2 | 4 | 1 | 6 | 5 | 9 |\x0d\交换后状态| 2 | 4 | 1 | 5 | 6 | 9 |\x0d\第五次两两比较,6 1交换\x0d\交换前状态| 2 | 4 | 1 | 5 | 6 | 9 | \x0d\交换后状态| 2 | 1 | 4 | 5 | 6 | 9 |\x0d\ \x0d\第三次两两比较,4 1交换\x0d\交换后状态| 2 | 1 | 4 | 5 | 6 | 9 |\x0d\交换后状态| 1 | 2 | 4 | 5 | 6 | 9 |\x0d\ \x0d\第二次两两比较,2

冒泡排序法

冒泡排序法,是C语言常用的排序算法之一,意思是对一组数字进行从大到小或者从小到大排序的一种算法 。

具体方法是:

相邻数值两两交换 。从第一个数值开始 ,如果相邻两个数的排列顺序与我们的期望不同,则将两个数的位置进行交换(对调);如果其与我们的期望一致,则不用交换。重复这样的过程 ,一直到最后没有数值需要交换,则排序完成。

C语言常见的排序算法:

1、冒泡排序

基本思想:比较相邻的两个数,如果前者比后者大 ,则进行交换 。每一轮排序结束 ,选出一个未排序中最大的数放到数组后面。

2、快速排序

基本思想:选取一个基准元素,通常为数组最后一个元素(或者第一个元素)。从前向后遍历数组,当遇到小于基准元素的元素时 ,把它和左边第一个大于基准元素的元素进行交换 。在利用分治策略从已经分好的两组中分别进行以上步骤,直到排序完成。

3 、直接插入排序

基本思想:和交换排序不同的是它不用进行交换操作,而是用一个临时变量存储当前值。当前面的元素比后面大时 ,先把后面的元素存入临时变量,前面元素的值放到后面元素位置,再到最后把其值插入到合适的数组位置 。

4、直接选择排序

基本思想:依次选出数组最小的数放到数组的前面。首先从数组的第二个元素开始往后遍历 ,找出最小的数放到第一个位置。再从剩下数组中找出最小的数放到第二个位置 。以此类推,直到数组有序。

以上内容参考 百度百科-排序算法、百度百科-c语言冒泡排序

 

 

#include<stdio.h>?

void main()?

{?

int a[10];?

int i,j,t;?

printf("input 10 numbers:\n");?

for(i=0;i<10;i++)?

scanf("%d",&a[i]);

for(j=0;j<9;j++) /*进行9次循环 实现9趟比较*/?

for(i=0;i<9-j;i++) /*在每一趟中进行9-j次比较*/?

if(a[i]>a[i+1]) /*相邻两个数比较,想降序只要改成a[i]<a[i+1]*/?

{?

t=a[i];?

a[i]=a[i+1];?

a[i+1]=t;?

}?

printf("the sorted numbers:\n");?

for(i=0;i<10;i++)?

printf(" %d",a[i]);

}

扩展资料:

冒泡排序算法的运作

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

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

3、针对所有的元素重复以上的步骤,除了最后已经选出的元素(有序)。

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

简单的表示

#include <stdio.h>

void swap(int *i, int *j)

{

int temp = *i;

*i = *j;

*j = temp;

}

int main()

{

int a[10] = {2,1,4,5,6,9,7,8,7,7};

int i,j;

for (i = 0; i < 10; i++)

{

for (j = 9; j > i; j--)//从后往前冒泡

{

if (a[j] < a[j-1])

{

swap(&a[j], &a[j-1]);

}

}

}

for (i = 0; i < 10; i++)

{

printf("%d\n", a[i]);

}

return 0;

}

冒泡排序-百度百科

关于“冒泡法排序”这个话题的介绍,今天小编就给大家分享完了,如果对你有所帮助请保持对本站的关注!

本文来自作者[雨陵殖]投稿,不代表幺幺号立场,如若转载,请注明出处:http://yyhz.net/yaoyao/632.html

(5)
雨陵殖的头像雨陵殖签约作者

文章推荐

发表回复

作者才能评论

评论列表(3条)

  • 雨陵殖的头像
    雨陵殖 2025年09月09日

    我是幺幺号的签约作者“雨陵殖”

  • 雨陵殖
    雨陵殖 2025年09月09日

    本文概览:网上有关“冒泡法排序”话题很是火热,小编也是针对冒泡法排序寻找了一些与之相关的一些信息进行分析,如果能碰巧解决你现在面临的问题,希望能够帮助到您。冒泡法排序如下:冒泡法排序它重...

  • 雨陵殖
    用户090909 2025年09月09日

    文章不错《冒泡法排序》内容很有帮助