冒泡法排序是各种初学者在学习数组与循环结构时都会练习的一种简单排序算法。

冒泡法的精髓在于比较相邻的两个元素,较大的元素会不断的排到队伍后面去,就像水里的泡泡一样不断向上跑。

想像一下倒在一个透明玻璃杯中的雪碧,杯底有很多个气泡,很多气泡同时向上升,现在我们抽象一下,假设气泡只能一个一个的向上升,那么所有气泡上升的过程就是排序的过程,实际上这样讲并不严谨。下面是一个例子。

先定义一个数组。预期排序后从小到大排列。

int[] arr = {9,6,8,2,7,1,5}; 里面的有7个元素 第一趟的排序后结果是 6 8 2 7 1 5 9

第二趟的排序后结果是 6 2 7 1 5 8 9

最后排序后的结果就是1 2 5 6 7 8 9


上面讲的很简略,也是大部分网上的教程所写的形式,有些天资超群的人一看就懂,但我们这些天赋更加超群的人还是需要看看更详细的分析。

第一趟排序中,是分几个小步完成的:

1、9和6作比较,9大,交换位置,序列变成 6982715

2、9和8做比较,9大,交换位置,序列变成 6892715

3、9和2作比较,9大,交换位置,序列变成 6829715

4、9和7作比较,9大,交换位置,序列变成 6827915

5、9和1作比较,9大,交换位置,序列变成 6827195

6、9和1作比较,9大,交换位置,序列变成 6827159

这样一趟下来就第一趟的排序后结果是 6 8 2 7 1 5 9,注意哦,这一趟我们排了6次。

第二趟也是这样排下来的:

1、6和8作比较,8大,不换位置,序列还是 6827159

2、8和2作比较,8大,交换位置,序列变成 6287159

3、8和7作比较,8大,交换位置,序列变成 6278159

4、8和1作比较,8大,交换位置,序列变成 6271859

5、8和5作比较,8大,交换位置,序列变成 6271589

这里8和9需不需要再比较呢,刚学的时候会有疑问,仔细想一想第一趟中,8和9已经比较过了,如果9和8的关系不确定,那么9就不会跑到最后面去了。所以这里不用再去比较最后的9和8了。实际上可以引入有序区和无序区的概念,每趟排序都会排出一个无序区中一个最大的数出来放到有序区去,那么有序区中的元素在放入的时候需不需要再排序呢,其实是不用的,你在构成有序区的时候已经默认了有序区第一个元素是最大的,第二个到有序区的元素是整个数组中第二大的,以此类推。注意哦,这一趟我们排了5次。

后面的几趟排序下来都可以用类似的方法去排下来。


那么如何在编码中实现呢?

整个排序分为两层,外层要控制排序的趟数,而且和序列的长度相关,仔细观察一下不难发现是序列长度-1。

伪代码

  1. for(){
  2. }

内层要做的是1控制该趟的比较次数,这个次数和第几趟有关;2比较相邻的两个元素,如果符合条件,就交换两个元素的位置,然后下一次比较就是往后面一位的相邻两元素。

伪代码

  1. for(){
  2. for(){
  3. if(){//如果符合条件
  4. //交换元素
  5. }
  6. }
  7. }

下面放源码

  1. package com.chapter.five;
  2. //需求 给入一个数组,输出一个从小到大排序好的数组,要求使用冒泡法
  3. //思路
  4. //冒泡法的精髓在于比较相邻的两个元素,较大的元素会不断的排到队伍后面去,就像水里的泡泡一样不断向上跑。
  5. //1n个元素就要遍历n-1次,外层用一个for循环做
  6. //2内层需要进行比较相邻的元素,如果符合第i个元素大于第i+1个元素,
  7. //3就交换两元素的位置,然后比较下一对元素,也就是i+1和i+2之间(这里的i+1已经是换位过的较大数)的关系,
  8. //这样就可以将较大的数不断的向后排出来
  9. class BubbleSort{
  10. public static void main(String[] args){
  11. int[] arr = {9,6,8,2,7,1,5};
  12. BubbleSort bs = new BubbleSort();
  13. bs.bubbleSort(arr);
  14. }
  15. void bubbleSort(int[] arr){
  16. System.out.println("排序前的数组是");
  17. for(int i:arr){
  18. System.out.print(i+" ");
  19. }
  20. for(int i = 0;i < arr.length;i++){//定量,冒泡一共进行多少次,实际上应该是长度减1次
  21. for(int j = 1;j < arr.length-i;j++){//因为进行了i次排序时,后面的第i位已经是有序的了,所以是长度减1
  22. if(arr[j-1] > arr[j] ){//如果符合条件就交换位置,不符合就不交换
  23. int temp = arr[j-1];
  24. arr[j-1] = arr[j];
  25. arr[j] = temp;
  26. }
  27. }
  28. }
  29. System.out.println("排序后的数组是");
  30. for(int i:arr){
  31. System.out.print(i+" ");
  32. }
  33. }
  34. }

Java温故而知新-冒泡法排序的更多相关文章

  1. Java - 双冒泡法排序

    最开始的代码 我采用的是我原来进行快速排序所用的方法,一直做不出来. 为什么我会采用原来快速排序的方法?因为我的记忆中好像就是这样的,因此我根据记忆中的快速排序在进行改变,然而,却无法真正的写出双冒泡 ...

  2. 【Java基础】选择排序、冒泡法排序、二分法查找

    1.选择排序: //改进后的选择排序,减少交换的次数 public static void sortSelect(int arr[]) { //用于存放最小数的下标 int s; for (int i ...

  3. [python,2018-01-15] 冒泡法排序

    想写一个冒泡法排序,没什么思路,就先写了个java的 public static void main(String[] args) { int array[] = {88,2,43,12,34,8,6 ...

  4. 8. 冒泡法排序和快速排序(基于openCV)

    一.前言 主要讲述冒泡法排序和快速排序的基本流程,并给出代码实现,亲测可用. 二.冒泡法排序 冒泡法排序主要是将相邻两个值比较,把小的向前冒泡,大的向后沉淀,时间复杂度为O(n2).主要思想如下: 分 ...

  5. Python 冒泡法排序

    def sequence(disorder='', separators=''): arrays = disorder.split(separators) def desc(): for i in r ...

  6. C#冒泡法排序源码

    如下内容内容是关于C#冒泡法排序的内容,应该对码农有一些用途. int[] myArray = new int[] { 10, 8, 3, 5, 6, 7, 4, 6, 9 }; for( int j ...

  7. C语言 · 冒泡法排序

    算法提高 冒泡法排序   时间限制:1.0s   内存限制:512.0MB      输入10个数,用“冒泡法”对10个数排序(由小到大)这10个数字在100以内. 样例输入 1 3 6 8 2 7 ...

  8. C程序数组算法 — 冒泡法排序【前冒 || 后冒】

    第一种写法(前冒泡): /* C程序数组算法 - 冒泡法排序 * 此例子按照 大 -> 小 排序 * 原理:两两相比较,然后进行大小对调 * 比较次数: n^2 次 * 说明:冒泡排序是相对稳定 ...

  9. 冒泡法排序_c++实现

    看完了郝斌老师的c语言视频,冒泡法排序,就试着写了.我觉得学习算法最重要的不是代码,而是它的原理. 代码: /** 2 * Copyright (c) 1991 - 2016 Arvin Tang. ...

随机推荐

  1. synchronized优化

    重量级锁 synchronized关键字 前文解释了synchronized的实现和运用,了解monitor的作用,但是由于monitor监视器锁的操作是基于操作系统的底层Mutex Lock实现的, ...

  2. Nancy基于JwtBearer认证的使用与实现

    前言 最近在看JSON Web Token(Jwt)相关的东西,但是发现在Nancy中直接使用Jwt的组件比较缺乏,所以就在空闲时间写了一个. 这个组件是开源的,不过目前只支持.NET Core,后续 ...

  3. FTP publisher plugin插件

    说明:这个插件可以将构建的产物(例如:Jar)发布到FTP中去. 官方说明:FTP publisher plugin 安装步骤: 系统管理→管理插件→可选插件→Artifact Uploaders→F ...

  4. 关于使用JQuery追加Option标签时使用三元运算符添加选中属性的解决办法

    $(data.resultList).each(function () {                        var selectedFlag = ${sessionScope.userI ...

  5. call和apply和bind区别

    call和apply特征一样 都是用来调用函数 立即调用 但是可以在调用函数的同时 通过第一个参数指定函数内部this的指向 call 调用的时候 参数必须以参数列表的形式进行传递 也就是以逗号分隔的 ...

  6. Asp.Net MVC-4-过滤器1:认证与授权

    基础 过滤器体现了MVC框架中的Aop思想,虽然这种实现并不完美但在实际的开发过程中一般也足以满足需求了. 过滤器分类 依据上篇分析的执行时机的不同可以把过滤器按照实现不同的接口分为下面五类: IAu ...

  7. codeforces 475D. CGCDSSQ

    D. CGCDSSQ time limit per test 2 seconds memory limit per test 256 megabytes Given a sequence of int ...

  8. 【RegExp】JavaScript中正则表达式判断匹配规则以及常用方法

    字符串是编程时涉及到的最多的一种数据结构,对字符串进行操作的需求几乎无处不在. 正则表达式是一种用来匹配字符串的强有力的武器.它的设计思想是用一种描述性的语言来给字符串定义一个规则,凡是符合规则的字符 ...

  9. 19. leetcode 100. Same Tree

    Given two binary trees, write a function to check if they are equal or not. Two binary trees are con ...

  10. S2-032代码执行

    Struts 2是Struts的下一代产品,是在 struts 1和WebWork的技术基础上进行了合并的全新的Struts 2框架.其全新的Struts 2的体系结构与Struts 1的体系结构差别 ...