快速排序算法递归与非递归实现

快速排序是对冒泡排序的一种改进。它的基本思想是:通过一躺排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一不部分的所有数据都要小,然后再按次方法对这两部分数据分别进行快速排序,整个排序过程可以递归或者非递归进行,以此达到整个数据变成有序序列。

快速排序的递归算法:

   void qsort(int a[],int left,int right)

  {

       int pivot,l,r,temp;

      

       l = left;

       r = right;

       pivot = a[(left+right)/2]; //取中位值作为分界值

 

       while(l<r)

       {

          while(a[l] < pivot) ++l;

          while(a[r] > pivot) --r;

      

          if(l>=r) break;

 

          temp = a[l];

          a[l] = a[r];

          a[r] = temp;

          ++l;

           --r;

        }

       

         if(l==r) l++;

         if(left < r) qsort(a, left,l-1);

         if(l < right) qsort(a,r+1,right);

  }

 

快速排序的非递归算法
#include <iostream>
#include <stack>
using namespace std;
template <class T>
int partition(T a[],int low,int high)
{
 T v=a[low];
 while(low<high)
 {  
  while(low<high && a[high]>=v) high--;
  a[low]=a[high];
  while(low<high && a[low]<=v) low++;
  a[high]=a[low];
 }
 a[low]=v;
 return low;
 
}
 
template <class T>
void QuickSort(T a[],int p,int q)
{
 stack<int> st;
 int j;
 do{
      while(p<q)
      {
         j=partition(a,p,q);   
         if( (j-p)<(q-j) )
         {
            st.push(j+1);
            st.push(q);
            q=j-1;
         }
         else
         {
           st.push(p);
           st.push(j-1);
           p=j+1;
         }   
      }
  if(st.empty()) return;
  q=st.top();st.pop();  
  p=st.top();st.pop();  
  //cout<<endl<<"p:"<<p<<" ";
  //cout<<"q:"<<q<<endl;
 }while(1);
}

void main()
{
 //int a[7]={7,6,5,4,3,2,1};
 //int a[7]={1,2,3,4,5,6,7};
 int a[7]={3,5,2,3,66,225,1};
 for(int i=0;i<7;i++)
  cout<<a[i]<<" ";
 QuickSort(a,0,6);
 cout<<endl;
 for(int i=0;i<7;i++)
  cout<<a[i]<<" ";
}  
  • 1
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值