冒泡排序算法(冒泡排序算法描述)

本篇文章给大家谈谈冒泡排序算法,以及冒泡排序算法描述对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。

本文目录一览:

冒泡排序法是什么

冒泡排序的英文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) 。

冒泡排序代码

希望对您有所帮助!~

[img]

冒泡排序算法有几种写法?

冒泡排序算法有两种,一种是从大到小排,另一种是从小到大排。

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

冒泡排序最核心的思想就是相邻的两个元素相比较,符合冒泡的才冒泡,重复多次执行,待最后没有需要冒泡的元素时才停止执行,表示排序已经完成。

冒泡排序也是一种稳定排序算法。因为冒泡排序就是把小的元素往前调或者把大的元素往后调。比较是相邻的两个元素比敏旦较,交换也发生在这两个元素之间。所以,如果桥御扰两个元素相等,是不会再交换的;如果两个相等的元素没有相邻,那么即使通过前面的两两交换把两个相邻起来,这时候也不会交换,所以相同元素的前后顺序并没有改变。

冒泡排序

冒泡排序(Bubble Sort)是一种典型的交换排序算法,通过交换数据元素的位置进行排序。

一、算法基本思想

(1)基本思想

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

算法的核心在于每次通过两两比较交换位置,选出剩余山尺无序序列里最大(小)的数据元素放到队尾。

(2)运行过程

冒泡排序算法的运作如下:

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

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

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

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

(3)示例

java 的如何实现冒泡算法呢?

其实有两种方法

一种是正序 

/*

* 正序冒泡

* */

public static void sortListAsc(Integer[] list){

if(list.length0){

for(int i=0;i

for(int j=0;j

int exchange=0;

                if(list[j]list[j+1]){

exchange= list[j+1];

                    list[j+1]=list[j];

                    list[j]=exchange;

                }

}

}

}

for(Integer k:list){

System.out.println(k);

    }

}

一种是反序 

/*

* 反序冒泡

* */

public static void sortListDesc(Integer[] list){

if(list.length0){

for(int i=(list.length-1);i0;i--){

for(int j=(list.length-1);j0;j--){

int a=0;

                      if(list[j]

a=list[j-1];

                          list[j-1]=list[j];

                          list[j]=a;

                      }

}

}

}

}

虽然实现的目标是相同的,但是实现的原理也一样  只不过流程是逆向的      

完成之后便是如此   

如果使用Stiring 字符串的compareTo 也可以是实现类似功能  

不过这个比较的是字符串的ASCII码值的大小  ,可以应用于数字字符串的比较, 如逗猜高此冒泡依旧可以使用。

//实现字符串的冒泡

public static String[]sortAscII(String[] list){

if(list.length0){

for(int i=(list.length-1);i0;i--){

for(int j=(list.length-1);j0;j--){

String a="";

                if(list[j].compareTo(list[j-1])0 ){

a=list[j-1];

                    list[j-1]=list[j];

                    list[j]=a;

                }

}

}

}

return list;

}

关于冒泡排序算法和冒泡排序算法描述的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。

标签列表