当前位置:  编程技术>c/c++/嵌入式

冒泡排序的三种实现方法

    来源: 互联网  发布时间:2014-10-21

    本文导语:  冒泡排序是非常容易理解和实现,以从小到大排序举例: 设数组长度为N。 1.比较相邻的前后二个数据,如果前面数据大于后面的数据,就将二个数据交换。 2.这样对数组的第0个数据到N-1个数据进行一次遍历后,最大的一个...

冒泡排序是非常容易理解和实现,以从小到大排序举例:

设数组长度为N。

1.比较相邻的前后二个数据,如果前面数据大于后面的数据,就将二个数据交换。

2.这样对数组的第0个数据到N-1个数据进行一次遍历后,最大的一个数据就“沉”到数组第N-1个位置。

3.N=N-1,如果N不为0就重复前面二步,否则排序完成。

按照定义很容易写出代码:

代码如下:

//冒泡排序1
void BubbleSort1(int a[], int n)
{
       int i, j;
       for (i = 0; i < n; i++)
              for (j = 1; j < n - i; j++)
                     if (a[j - 1] > a[j])
                            Swap(a[j - 1], a[j]);
}

下面对其进行优化,设置一个标志,如果这一趟发生了交换,则为true,否则为false。明显如果有一趟没有发生交换,说明排序已经完成。
代码如下:

//冒泡排序2
void BubbleSort2(int a[], int n)
{
       int j, k;
       bool flag;

       k = n;
       flag = true;
       while (flag)
       {
              flag = false;
              for (j = 1; j < k; j++)
                     if (a[j - 1] > a[j])
                     {
                            Swap(a[j - 1], a[j]);
                            flag = true;
                     }
              k--;
       }
}


再做进一步的优化。如果有100个数的数组,仅前面10个无序,后面90个都已排好序且都大于前面10个数字,那么在第一趟遍历后,最后发生交换的位置必定小于10,且这个位置之后的数据必定已经有序了,记录下这位置,第二次只要从数组头部遍历到这个位置就可以了。
代码如下:

//冒泡排序3
void BubbleSort3(int a[], int n)
{
 int j, k;
 int flag;

 flag = n;
 while (flag > 0)
 {
  k = flag;
  flag = 0;
  for (j = 1; j < k; j++)
   if (a[j - 1] > a[j])
   {
    Swap(a[j - 1], a[j]);
    flag = j;
   }
 }
}

冒泡排序毕竟是一种效率低下的排序方法,在数据规模很小时,可以采用。数据规模比较大时,最好用其它排序方法。

    
 
 

您可能感兴趣的文章:

  • <<大话数据结构>>中冒泡排序算法改进
  • php冒泡排序算法实现代码
  • 又一个PHP实现的冒泡排序算法分享
  • php排序算法 PHP版快速排序与冒泡排序
  • java冒泡排序算法代码
  • C经典冒泡排序法实现代码
  • Java中的数组排序方式(快速排序、冒泡排序、选择排序)
  • python冒泡排序算法的实现代码
  • Python实现冒泡,插入,选择排序简单实例
  • c#冒泡排序示例分享
  • c#冒泡排序算法示例
  • 排序算法之PHP版快速排序、冒泡排序
  • C++冒泡排序算法实例
  • c++冒泡排序示例分享
  • 深入Java冒泡排序与选择排序的区别详解
  • shell编程中的冒泡排序问题
  • c语言冒泡排序法代码
  • 控制台显示java冒泡排序流程示例
  • Java冒泡排序(Bubble Sort)实例讲解
  • java冒泡排序和选择排序示例
  • 冒泡排序算法原理及JAVA实现代码
  • 用java实现冒泡排序算法
  • 用c语言实现冒泡排序,选择排序,快速排序
  • 冒泡算法的改进具体实现
  • c语言实现冒泡排序、希尔排序等多种算法示例
  • C++ 基本算法 冒泡法、交换法、选择法、实现代码集合
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • JQuery中阻止事件冒泡几种方式及其区别介绍
  • jQuery中阻止冒泡事件的方法介绍
  • jQuery中事件对象e的事件冒泡用法示例介绍
  • 一个小例子解释如何来阻止Jquery事件冒泡
  • 关于javascript冒泡与默认事件的使用详解
  • C++ 冒泡排序数据结构、算法及改进算法
  • c# 冒泡排序算法(Bubble Sort) 附实例代码
  • java数组排序示例(冒泡排序、快速排序、希尔排序、选择排序)
  • java 合并排序算法、冒泡排序算法、选择排序算法、插入排序算法、快速排序算法的描述


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3