网上有关“冒泡法排序”话题很是火热,小编也是针对冒泡法排序寻找了一些与之相关的一些信息进行分析 ,如果能碰巧解决你现在面临的问题,希望能够帮助到您。
冒泡法排序如下:
冒泡法排序它重复地走访过要排序的元素列,依次比较两个相邻的元素 ,如果顺序(如从大到小、首字母从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
评论列表(3条)
我是幺幺号的签约作者“雨陵殖”
本文概览:网上有关“冒泡法排序”话题很是火热,小编也是针对冒泡法排序寻找了一些与之相关的一些信息进行分析,如果能碰巧解决你现在面临的问题,希望能够帮助到您。冒泡法排序如下:冒泡法排序它重...
文章不错《冒泡法排序》内容很有帮助