“JAVA写冒泡排序”是什么意思?

我想用我的索爱W705下载“冒泡” 可是不知道能不能下载,在百度搜索,看到了{JAVA对冒泡的排序}我非常不解,请教高手解答!

冒泡排序的英文Bubble Sort,是一种最基础的交换排序。

  大家一定都喝过汽水,汽水中常常有许多小小的气泡,哗啦哗啦飘到上面来。这是因为组成小气泡的二氧化碳比水要轻,所以小气泡可以一点一点向上浮动。而我们的冒泡排序之所以叫做冒泡排序,正是因为这种排序算法的每一个元素都可以像小气泡一样,根据自身大小,一点一点向着数组的一侧移动。

冒泡排序算法的原理如下:

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

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

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

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

    具体如何来移动呢?让我们来看一个栗子:

    请点击输入图片描述

    请点击输入图片描述

    有8个数组成一个无序数列:5,8,6,3,9,2,1,7,希望从小到大排序。按照冒泡排序的思想,我们要把相邻的元素两两比较,根据大小来交换元素的位置,过程如下:

    首先让5和8比较,发现5比8要小,因此元素位置不变。

    接下来让8和6比较,发现8比6要大,所以8和6交换位置。

    请点击输入图片描述

    请点击输入图片描述

    请点击输入图片描述

    请点击输入图片描述

    继续让8和3比较,发现8比3要大,所以8和3交换位置。

    请点击输入图片描述

    请点击输入图片描述

    请点击输入图片描述

    请点击输入图片描述

    继续让8和9比较,发现8比9要小,所以元素位置不变。

    接下来让9和2比较,发现9比2要大,所以9和2交换位置。

    请点击输入图片描述

    请点击输入图片描述

    请点击输入图片描述

    请点击输入图片描述

    接下来让9和1比较,发现9比1要大,所以9和1交换位置。

    请点击输入图片描述

    请点击输入图片描述

    请点击输入图片描述

    请点击输入图片描述

    最后让9和7比较,发现9比7要大,所以9和7交换位置。

    请点击输入图片描述

    请点击输入图片描述

    请点击输入图片描述

    请点击输入图片描述

    这样一来,元素9作为数列的最大元素,就像是汽水里的小气泡一样漂啊漂,漂到了最右侧。

    这时候,我们的冒泡排序的第一轮结束了。数列最右侧的元素9可以认为是一个有序区域,有序区域目前只有一个元素。

    请点击输入图片描述

    请点击输入图片描述

    下面,让我们来进行第二轮排序:

    首先让5和6比较,发现5比6要小,因此元素位置不变。

    接下来让6和3比较,发现6比3要大,所以6和3交换位置。

    请点击输入图片描述

    请点击输入图片描述

    请点击输入图片描述

    请点击输入图片描述

    继续让6和8比较,发现6比8要小,因此元素位置不变。

    接下来让8和2比较,发现8比2要大,所以8和2交换位置。

    请点击输入图片描述

    请点击输入图片描述

    接下来让8和1比较,发现8比1要大,所以8和1交换位置。

    请点击输入图片描述

    请点击输入图片描述

    请点击输入图片描述

    请点击输入图片描述

    继续让8和7比较,发现8比7要大,所以8和7交换位置。

    请点击输入图片描述

    请点击输入图片描述

    请点击输入图片描述

    请点击输入图片描述

    第二轮排序结束后,我们数列右侧的有序区有了两个元素,顺序如下:

    请点击输入图片描述

    请点击输入图片描述

    至于后续的交换细节,我们这里就不详细描述了,第三轮过后的状态如下:

    请点击输入图片描述

    请点击输入图片描述

    第四轮过后状态如下:

    请点击输入图片描述

    请点击输入图片描述

    第五轮过后状态如下:

    请点击输入图片描述

    请点击输入图片描述

    第六轮过后状态如下:

    请点击输入图片描述

    请点击输入图片描述

    第七轮过后状态如下(已经是有序了,所以没有改变):

    请点击输入图片描述

    请点击输入图片描述

    第八轮过后状态如下(同样没有改变):

    请点击输入图片描述

    请点击输入图片描述

    到此为止,所有元素都是有序的了,这就是冒泡排序的整体思路。

    原始的冒泡排序是稳定排序。由于该排序算法的每一轮要遍历所有元素,轮转的次数和元素数量相当,所以时间复杂度是O(N^2) 。

    冒泡排序代码

    请点击输入图片描述

    请点击输入图片描述

    希望对您有所帮助!~

温馨提示:内容为网友见解,仅供参考
第1个回答  2010-06-12
按冒泡排序思想,有8颗豆子(大小不一)放在8袋子里,从第1个袋了拿出豆子,与第2个袋子里的豆子相比较,如果第2个袋子里豆子比第1个袋子的豆子大,就把第2个袋子里的豆子放入第1个袋子,把第1个袋子的豆子放入第2个袋子。然后,第1个袋子继续和第3个袋子比较。如果第2袋子的豆子不会比第1个袋子的大,就和第3个袋子比较,这样一一个下直到和所有的袋子比较过。之后第2个袋子也与第2个袋子以后的相比较过.......!
另外还要用到交换的方法:
代码主要是用循环嵌套:
public class NewMain {
public static void main(String[] args) {
// TODO code application logic here
int a[]={1,5,8,11,16,30,40,50,199};//定义一个数组,也可写成 int[] a={1,5,8,11,16,30,40,50,199};
int c;//用于交换用的
for(int i=0;i<a.length;i++){ //a.length 数组的长度
for(int j=i+1;j<a.length;j++){
if(a[j]>a[i]){ // 进行交换
c=a[j];
a[j]=a[i];
a[i]=c;
}
}
System.out.println(a[i]);
}
}本回答被网友采纳
第2个回答  2010-06-12
由于在排序过程中总是小数往前放,大数往后放,相当于气泡往上升,所以称作冒泡排序。

参考资料:http://baike.baidu.com/view/254413.htm

Java实现几种常见排序方法
冒泡排序是一个比较简单的排序方法。在待排序的数列基本有序的情况下排序速度较快。若要排序的数有n个,则需要n-1轮排序,第j轮排序中,从第一个数开始,相邻两数比较,若不符合所要求的顺序,则交换两者的位置;直到第n+1-j个数为止,第一个数与第二个数比较,第二个数与第三个数比较,......

java冒泡升序排列
Java冒泡升序排列就是使用Java语言实现冒泡,将待排元素按照从小到大的顺序进行排列。冒泡排序的现象:较大的元素会“下沉”,较小的元素会“上浮”。冒泡排序的理解:第一次找到所有元素中最大的元素放在倒数第一位不再变动,第二次再找到剩余元素中最大的元素放到倒数第二位不再变动,依此类推,直到...

Java冒泡排序的原理?
冒泡排序是所欲排序算法里最好理解的了。1、排序算法:A)比较相邻的元素。如果第一个比第二个大,就交换他们两个。B)对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。在这一点,最后的元素应该会是最大的数。C)针对所有的元素重复以上的步骤,除了最后一个。D)持续每次对越来越少...

Java冒泡排序中i、j各代表什么意思?
没有什么特别的含义。冒泡排序(Bubble Sort,台湾译为:泡沫排序或气泡排序)是一种简单的排序算法。它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。这个算法的名字由来是因为越大的元素...

用java冒泡排序和递归算法
冒泡排序 (1)基本思想:在要排序的一组数中,对当前还未排好序的范围内的全部数,自上而下对相邻的两个数依次进行比较和调整,让较大的数往下沉,较小的往上冒。即:每当两相邻的数比较后发现它们的排序与排序要求相反时,就将它们互换。(2)用java实现 ubli cclass bubbleSort { public ...

冒泡排序
冒泡排序的基本思想就是:从无序序列头部开始,进行两两比较,根据大小交换位置,直到最后将最大(小)的数据元素交换到了无序队列的队尾,从而成为有序序列的一部分;下一次继续这个过程,直到所有数据元素都排好序。算法的核心在于每次通过两两比较交换位置,选出剩余无序序列里最大(小)的数据元素...

冒泡排序是什么意思?
如此下去,重复以上过程,直至最终完成排序。问题二:冒泡排列是什么意思? 就是给你一些哗字,然后用算法把他从大到小排序。因为是大的往前一个个的放,就像水里的泡泡一样,故而的名。问题三:“JAVA写冒泡排序”是什么意思? 10分 按冒泡排序思想,有8颗豆子(大小不一)放在8袋子里,从第1个...

java冒泡排序详细讲解
冒泡排序的算法思想是:1、比较相邻的元素。如果第一个比第二个大,就交换他们两个。2、对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。在这一点,最后的元素应该会是最大的数。3、针对所有的元素重复以上的步骤,除了最后一个。4、持续每次对越来越少的元素重复上面的步骤,直到没...

Java和C#一共有几种排序方法
1、冒泡排序属于稳定排序,是一种借助“交换”进行排序的方法。首先要将第一个记录的关键字和第二个记录的关键字进行比较,若为逆序,则将两个记录交换之,然后比较第二个记录与第三个记录的关键字,以此类推,直至第n-1个记录与第n个记录的关键字进行比较为止,这一过程称为第一趟冒泡排序,其结果...

java中冒泡排序算法的详细解答以及程序?
实例解析 交换排序的基本思想是两两比较待排序记录的关键字,发现两个记录的次序相反时即进行交换,直到没有反序的记录为止。 应用交换排序基本思想的主要排序方法有冒泡排序和快速排序。 冒泡排序 将被排序的记录数组 R[1..n] 垂直排列,每个记录 R[i] 看做是重量为 R[i].key 的气泡。根据轻气泡...

相似回答