Visual C++下对冒泡排序算法的改进

原创 2006年05月29日 23:26:00
排序是在程序设计中常碰到的问题,排序算法也有很多种。起泡法是众所周知的排序算法,其原理是每次将相邻两个数进行比较,较大的下沉。其的主程序段如下(用VC++实现):

Void Bubble Sort (int* pData,int Count)
{
 Int iTemp;
 for(int i=1;i<Count;i++)
 {
  For (int j=Count-1;j>=i;j--)
  {
   if(pData[j]<pData[j-1])
   {
    iTemp = pData[j-1];
    pData[j-1] = pData[j];
    pData[j] = iTemp;
   }
  }
 }
}

  我们分析上述程序段可以发现起泡法是从一端开始比较的,第一次循环就是把最小数上升到第一位置,第二次循环就是把第二最小数上升到第二位置。如此循环实现数据的排序。那么我们是否可以找到最小数的同时找到最大数呢?当然可以。方法是在一端起泡时同时在另一端也进行起泡。即反向起泡。下面的程序段实现的是双向起泡:

void Bubble2Sort(int* pData,int Count)
{
 int iTemp;
 int left = 1;
 int right =Count -1;
 int t;
 do
 {
  //正向的部分
  for(int i=right;i>=left;i--)
  {
   if(pData[i]<pData[i-1])
   {
    iTemp = pData[i];
    pData[i] = pData[i-1];
    pData[i-1] = iTemp;
    t = i;
   }
  }
  left = t+1;
  //反向的部分
  for(i=left;i<right+1;i++)
  {
   if(pData[i]<pData[i-1])
   {
    iTemp = pData[i];
    pData[i] = pData[i-1];
    pData[i-1] = iTemp;
    t = i;
   }
  }
  right = t-1;
 }while(left<=right);
}

  分析上面的程序段我们可以发现正向起泡时第一次循环找出了最小数,反向起泡第一次循环找到最大数。很显然在一次循环中即可以找到一个最小的数还可以找到一个最大的数,所以用双向冒泡排序的交换的次数减少了,从而达到了优化起泡法的作用。

冒泡排序算法的C++函数模板

  • 2011年11月14日 17:08
  • 14KB
  • 下载

C++ 冒泡排序算法的实现与改进(含笔试面试题)

冒泡排序(Bubble sort)也是一种简单直观的排序算法。它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。走访数列的工作是重复地进行直到没有再需要交换,也就是说该...

冒泡排序算法详解C++程序

冒泡排序算法:(Bubble Sort)首先肯定是一种简单的排序算法,它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。 用C++实现冒泡算法...

自己写的冒泡排序算法

  • 2017年12月07日 14:25
  • 2KB
  • 下载

冒泡排序算法

  • 2013年08月06日 21:35
  • 2KB
  • 下载

C++程序设计实验报告(十七)----实现冒泡排序算法,并将之定义为一个函数

第15周报告1: 实验目的:学会冒泡排序算法 实验内容:实现冒泡排序算法,并将之定义为一个函数 * 程序头部注释开始 * 程序的版权和版本声明部分 * Copyright (c) 201...

冒泡排序算法

  • 2013年03月18日 12:01
  • 403B
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Visual C++下对冒泡排序算法的改进
举报原因:
原因补充:

(最多只允许输入30个字)