真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

如何在C語言中實(shí)現(xiàn)快速排序-創(chuàng)新互聯(lián)

如何在C語言中實(shí)現(xiàn)快速排序?相信很多沒有經(jīng)驗(yàn)的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。

成都創(chuàng)新互聯(lián)服務(wù)項(xiàng)目包括瓊海網(wǎng)站建設(shè)、瓊海網(wǎng)站制作、瓊海網(wǎng)頁制作以及瓊海網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,瓊海網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到瓊海省份的部分城市,未來相信會繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!

快速排序的遞歸算法

#include 
#include 
#include 
#include 
#include 
#include 
using namespace std;
#define OK 1
#define ERROR -1
#define TRUE 1
#define FALSE 0
typedef int Status;
//輸出函數(shù)
void Print(int a[], int l, int r)
{
 int i;
 for(i = l; i <= r; i++)
 {
  printf("%d ", a[i]);
 }
 printf("\n");
}
//劃分函數(shù)
int partion(int a[], int left, int right)
{
 //取最右邊的元素作劃分元素
 int temp = a[right];
 //記錄 i = left, j = right
 int i = left, j = right-1;
 //循環(huán)直到左右指針相遇
 while(true)
 {
  //從左邊開始掃描,當(dāng)出現(xiàn)比劃分元素大的元素,掃描停止
  while(temp > a[i])
  {
   i++;
  }
  //從右邊進(jìn)行掃描,當(dāng)出現(xiàn)比劃分元素小的元素,掃描停止
  while(temp < a[j] && j >= left)
  {
   j--;
  }
  //如果 i >= j, 循環(huán)截止,下面的交換不執(zhí)行
  if(i >= j) break;
  //交換停止時的元素
  swap(a[i], a[j]);
 }
 //交換該元素與劃分元素
 swap(a[i], a[right]);
 Print(a, 0, 6);
 //printf("i = %d", i);
 //劃分過程結(jié)束
 return i;
}
//快速排序
void qsort(int a[], int left, int right)
{
 //排序完成,循環(huán)截止
 if(right <= left)
  return;
 //做劃分
 int i = partion(a, left, right);
 //對左部分排序
 if(left < (i-1))
  printf("對%d~%d排序\n", left, i-1), qsort(a, left, i-1);
 //對右部分排序
 if(right > (i+1))
  printf("對%d~%d排序\n", i+1, right), qsort(a, i+1, right);
}
int main()
{
 int a[7] = {2, 5, 3, 7, 6, 1, 4};
 //快速排序
 printf("對0~6排序\n");
 qsort(a, 0, 6);
 Print(a, 0, 6);
 return 0;
}

非遞歸快速排序

快速排序的非遞歸實(shí)現(xiàn)使用了一個顯式的下推棧,使用向棧中壓入?yún)?shù)和過程調(diào)用/退出不斷地從棧中彈出參數(shù)來替代遞歸調(diào)用,這個過程繼續(xù)直到棧為空.我們把兩個子數(shù)組中的較大者壓入棧中來確保大棧的深度為lgN,如果對N個元素進(jìn)行排序.

void qsort(int a[], int left, int right)
{
 int i;
 //定義棧s
 stack s;
 //先判斷棧是否為空
 while(!s.empty())
 {
  //若棧不為空,將棧中元素移出
  s.pop();
 }
 //將right入棧
 s.push(right);
 //將left入棧
 s.push(left);
 //while循環(huán),當(dāng)棧為空時,循環(huán)結(jié)束
 while(!s.empty())
 {
  //元素left出棧
  left = s.top(), s.pop();
  //元素right出棧
  right = s.top(), s.pop();
  //判斷l(xiāng)eft與right的關(guān)系,如果left>=right,continue
  if(left >= right)
  {
   continue;
  }
  //作劃分
  i = partion(a, left, right);
  //比較兩個子數(shù)組的大小
  //將子數(shù)組中的較大者壓入棧
  if((i-1-left) > (right-i-1))
  {
   s.push(i-1);
   s.push(left);
   s.push(i+1);
   s.push(right);
  }
  else
  {
   s.push(i+1);
   s.push(right);
   s.push(i-1);
   s.push(left);
  }
 }
}

看完上述內(nèi)容,你們掌握如何在C語言中實(shí)現(xiàn)快速排序的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司行業(yè)資訊頻道,感謝各位的閱讀!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站www.cdcxhl.com,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。


網(wǎng)站題目:如何在C語言中實(shí)現(xiàn)快速排序-創(chuàng)新互聯(lián)
文章源于:http://weahome.cn/article/ceipei.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部