91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何在C語言中實現快速排序

發布時間:2021-05-27 18:23:38 來源:億速云 閱讀:149 作者:Leah 欄目:編程語言

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

快速排序的遞歸算法

#include <cstdio>
#include <cstdlib>
#include <algorithm>
#include <stack>
#include <queue>
#include <malloc.h>
using namespace std;
#define OK 1
#define ERROR -1
#define TRUE 1
#define FALSE 0
typedef int Status;
//輸出函數
void Print(int a[], int l, int r)
{
 int i;
 for(i = l; i <= r; i++)
 {
  printf("%d ", a[i]);
 }
 printf("\n");
}
//劃分函數
int partion(int a[], int left, int right)
{
 //取最右邊的元素作劃分元素
 int temp = a[right];
 //記錄 i = left, j = right
 int i = left, j = right-1;
 //循環直到左右指針相遇
 while(true)
 {
  //從左邊開始掃描,當出現比劃分元素大的元素,掃描停止
  while(temp > a[i])
  {
   i++;
  }
  //從右邊進行掃描,當出現比劃分元素小的元素,掃描停止
  while(temp < a[j] && j >= left)
  {
   j--;
  }
  //如果 i >= j, 循環截止,下面的交換不執行
  if(i >= j) break;
  //交換停止時的元素
  swap(a[i], a[j]);
 }
 //交換該元素與劃分元素
 swap(a[i], a[right]);
 Print(a, 0, 6);
 //printf("i = %d", i);
 //劃分過程結束
 return i;
}
//快速排序
void qsort(int a[], int left, int right)
{
 //排序完成,循環截止
 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;
}

非遞歸快速排序

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

void qsort(int a[], int left, int right)
{
 int i;
 //定義棧s
 stack<int> s;
 //先判斷棧是否為空
 while(!s.empty())
 {
  //若棧不為空,將棧中元素移出
  s.pop();
 }
 //將right入棧
 s.push(right);
 //將left入棧
 s.push(left);
 //while循環,當棧為空時,循環結束
 while(!s.empty())
 {
  //元素left出棧
  left = s.top(), s.pop();
  //元素right出棧
  right = s.top(), s.pop();
  //判斷left與right的關系,如果left>=right,continue
  if(left >= right)
  {
   continue;
  }
  //作劃分
  i = partion(a, left, right);
  //比較兩個子數組的大小
  //將子數組中的較大者壓入棧
  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);
  }
 }
}

看完上述內容,你們掌握如何在C語言中實現快速排序的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

芮城县| 北海市| 当阳市| 乃东县| 龙山县| 河间市| 十堰市| 保德县| 黑龙江省| 独山县| 佛山市| 肇庆市| 龙南县| 海阳市| 乌拉特前旗| 庆元县| 介休市| 敦煌市| 平江县| 玉屏| 大埔县| 庆安县| 民勤县| 郑州市| 海兴县| 南平市| 白玉县| 尼玛县| 泸西县| 咸阳市| 温泉县| 务川| 焉耆| 呼玛县| 鄂伦春自治旗| 山西省| 如皋市| 庆云县| 青州市| 松江区| 武乡县|