原理

将相邻的数据两两进行比较,按照从小到大或者从大到小的顺序进行位置交换,这样一趟过去后,最大或最小的数字被交换到了最后一位,然后从头开始再次进行两两比较交换,直到倒数第二位时结束。按照此规则,若干趟数据便按照了从小到大或者从大到小完成了排序。

例子

将数组[3,6,4,2,5,1]进行从大到小排序

第一趟排序

第一次两两比较,3<6 交换

交换前:| 3 | 6 | 4 | 2 | 5 | 1 |

交换后:| 6 | 3 | 4 | 2 | 5 | 1 |

第二次两两比较,3<4 交换

交换前:| 6 | 3 | 4 | 2 | 5 | 1 |

交换后:| 6 | 4 | 3 | 2 | 5 | 1 |

第三次两两比较,3>2 不交换

交换前:| 6 | 4 | 3 | 2 | 5 | 1 |

交换后:| 6 | 4 | 3 | 2 | 5 | 1 |

第四次两两比较,2<5交换

交换前:| 6 | 4 | 3 | 2 | 5 | 1 |

交换后:| 6 | 4 | 3 | 5 | 2 | 1 |

第五次两两比较,2>1不交换

交换前:| 6 | 4 | 3 | 2 | 2 | 1 |

交换后:| 6 | 4 | 3 | 5 | 2 | 1 |

第二趟排序

第一次两两比较,6>4不交换

交换前:| 6 | 4 | 3 | 5 | 2 | 1 |

交换后:| 6 | 4 | 3 | 5 | 2 | 1 |

第二次两两比较,4>3不交换

交换前:| 6 | 4 | 3 | 5 | 2 | 1 |

交换后:| 6 | 4 | 3 | 5 | 2 | 1 |

第二次两两比较,3<5交换

交换前:| 6 | 4 | 3 | 5 | 2 | 1 |

交换后:| 6 | 4 | 5 | 3 | 2 | 1 |

第三次两两比较,3>2不交换

交换前:| 6 | 4 | 5 | 3 | 2 | 1 |

交换后:| 6 | 4 | 5 | 3 | 2 | 1 |

第三趟排序

第一次两两比较,6>4不交换

交换前:| 6 | 4 | 5 | 3 | 2 | 1 |

交换后:| 6 | 4 | 5 | 3 | 2 | 1 |

第二次两两比较,4<5交换

交换前:| 6 | 4 | 5 | 3 | 2 | 1 |

交换后:| 6 | 5 | 4 | 3 | 2 | 1 |

第三次两两比较,4>3不交换

交换前:| 6 | 5 | 4 | 3 | 2 | 1 |

交换后:| 6 | 5 | 4 | 3 | 2 | 1 |

第四趟排序无交换

第五趟排序无交换

至此,排序完毕,输出最终结果6 5 4 3 2 1

动画演示

代码参考

        static void Main(string[] args)
{
int[] intArray = { , , , , , };
Bubble_Sort(intArray); foreach (var item in intArray)
{
Console.WriteLine(item);
}
Console.ReadLine();
} static void Bubble_Sort(int[] unsorted)
{
int temp;
for (int i = ; i < unsorted.Length - 1; i++)
{
for (int j = ; j < unsorted.Length - 1 - i; j++)
{
if (unsorted[j] < unsorted[j + 1])
{
temp = unsorted[j];
unsorted[j] = unsorted[j + 1];
unsorted[j + 1] = temp;
}
}
}
}

算法优化

假如一个数组进行很少趟就能排成有序数组,那么运行上面的代码就有点浪费了。对算法进行优化,详情请看一下代码

     static void Bubble_Sort(int[] unsorted)
{
int temp;
bool flag; //新增标志位
for (int i = ; i < unsorted.Length - 1; i++)
{
flag = false;
for (int j = ; j < unsorted.Length - 1 - i; j++)
{
if (unsorted[j] < unsorted[j + 1])
{
temp = unsorted[j];
unsorted[j] = unsorted[j + 1];
unsorted[j + 1] = temp;
flag = true; //发生交换,则标志位改变
}
} //数据未发生1次交换,标志位不变,表示数组已为有序装态,可提前结束外层循环
if (!flag)
{
break;
}
}
}

参考资料

http://www.blogjava.net/todayx-org/archive/2012/01/08/368091.html

基础算法之冒泡排序Bubble Sort的更多相关文章

  1. Java中的经典算法之冒泡排序(Bubble Sort)

    Java中的经典算法之冒泡排序(Bubble Sort) 神话丿小王子的博客主页 原理:比较两个相邻的元素,将值大的元素交换至右端. 思路:依次比较相邻的两个数,将小数放在前面,大数放在后面.即在第一 ...

  2. java排序算法之冒泡排序(Bubble Sort)

    java排序算法之冒泡排序(Bubble Sort) 原理:比较两个相邻的元素,将值大的元素交换至右端. 思路:依次比较相邻的两个数,将小数放在前面,大数放在后面.即在第一趟:首先比较第1个和第2个数 ...

  3. 【排序算法】冒泡排序(Bubble Sort)

    0. 说明 参考 维基百科中的冒泡排序 冒泡排序 (Bubble Sort) 是与插入排序拥有相等的执行时间,但是两种算法在需要的交换次数却很大地不同. 在最坏的情况,冒泡排序需要 O(n2)  次交 ...

  4. 快速排序算法回顾 --冒泡排序Bubble Sort和快速排序Quick Sort(Python实现)

    冒泡排序的过程是首先将第一个记录的关键字和第二个记录的关键字进行比较,若为逆序,则将两个记录交换,然后比较第二个记录和第三个记录的关键字.以此类推,直至第n-1个记录和第n个记录的关键字进行过比较为止 ...

  5. c#经典算法之冒泡排序(Bubble Sort)

    转载于:https://www.cnblogs.com/shen-hua/p/5422676.html 原理:比较两个相邻的元素,将值大的元素交换至右端. 思路:依次比较相邻的两个数,将小数放在前面, ...

  6. 分享知识-快乐自己:Java中的经典算法之冒泡排序(Bubble Sort)

    原理:比较两个相邻的元素,将值大的元素交换至右端. 思路:依次比较相邻的两个数,将小数放在前面,大数放在后面.即在第一趟:首先比较第1个和第2个数,将小数放前,大数放后.然后比较第2个数和第3个数,将 ...

  7. 排序算法--冒泡排序(Bubble Sort)_C#程序实现

    排序算法--冒泡排序(Bubble Sort)_C#程序实现 排序(Sort)是计算机程序设计中的一种重要操作,也是日常生活中经常遇到的问题.例如,字典中的单词是以字母的顺序排列,否则,使用起来非常困 ...

  8. 冒泡排序(Bubble Sort),比较次数优化改进

    body, table{font-family: 微软雅黑; font-size: 13.5pt} table{border-collapse: collapse; border: solid gra ...

  9. [算法] 冒泡排序 Bubble Sort

    冒泡排序(Bubble Sort,台湾另外一种译名为:泡沫排序)是一种简单的排序算法.它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来.走访数列的工作是重复地进行直到没 ...

随机推荐

  1. 30分钟学会如何使用Shiro

    本篇内容大多总结自张开涛的<跟我学Shiro>原文地址:http://jinnianshilongnian.iteye.com/blog/2018936 我并没有全部看完,只是选择了一部分 ...

  2. Struts2 基本配置

    Struts2是一个优秀的MVC框架,也是我比较喜欢用的框架.它个各种配置基本都可以集中在一个xml文档中完成.现在让我们看看如何简单几步实现常用功能. 一.搭建Struts2的开发环境 1)首先是利 ...

  3. java开发中中文乱码总结

    1.jsp页面内容显示乱码 这种乱码原因很简单,一般的工具或解码程序对中文字符解析时采用默认的解码方式: <%@ page contentType="text/html; charse ...

  4. php使用内置的mcrypt_encrypt和mcrypt_decrypt进行字符串加密解密

    <?php /*****************************加密*******************************/$key = "miyao";// ...

  5. Nginx与Lua利用fpm打成rpm包

    1.下载相关软件 需要软件有:Nginx,LuaJIT,ngx_devel_kit,ngx_lua等安装文件 安装Lua或者LuaJIT都是可以的,但是出于效率的考虑,推荐安装LuaJITshell& ...

  6. 您可能不曾注意的C++内置类型选择和使用的注意事项

    写在前面: 太忙了,好久没有写博客.这篇文章是在下读C++ Primer中文第五版(与以往版本相比,第五版的一大特色就是“为新的C++11标准重新撰写”——引自封皮)时的笔记,没有什么技术含量,只是作 ...

  7. word 文档 一次性设置多张图片大小

    1.打开WORD文档,插入多张图片. 2.在word中按alt+f11组合键,进入VBA模式. 3.在左边的工程资源管理器中找到你的word文档,在其上右键/添加/模块 4.复制以下代码 Sub Ma ...

  8. Kanzi编程基础1 - 定时器Timer

    Kanzi虽然发生了比较多的版本更迭,api也发生了很多变化,但定时器的头文件一直都在一个地方:#include "user/include/user/ui/message/kzu_mess ...

  9. jsp页面输出序号

    <c:forEach items="${tests}" var="test" varStatus="s"> <li> ...

  10. 相机位姿估计0:基本原理之如何解PNP问题

    关键词:相机位姿估计 PNP问题求解 用途:各种位姿估计 文章类型:原理 @Author:VShawn(singlex@foxmail.com) @Date:2016-11-18 @Lab: CvLa ...