亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C/C++實(shí)現(xiàn)快速排序算法的思路及原理解析

 更新時(shí)間:2021年01月12日 10:35:29   作者:有人_295  
這篇文章主要介紹了C/C++實(shí)現(xiàn)快速排序算法的思路及原理解析,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

快速排序

1. 算法思想

快速排序的基本思想:通過一趟排序?qū)⒋庞涗浄指舫瑟?dú)立的兩部分,其中一部分記錄的關(guān)鍵字均比另一部分的關(guān)鍵字小,則可分別對(duì)這兩部分記錄繼續(xù)進(jìn)行排序,以達(dá)到整個(gè)序列有序。

2. 實(shí)現(xiàn)原理

2.1、設(shè)置兩個(gè)變量 low、high,排序開始時(shí):low=0,high=size-1。
2.2、整個(gè)數(shù)組找基準(zhǔn)正確位置,所有元素比基準(zhǔn)值小的擺放在基準(zhǔn)前面,所有元素比基準(zhǔn)值大的擺在基準(zhǔn)的后面

  • 默認(rèn)數(shù)組的第一個(gè)數(shù)為基準(zhǔn)數(shù)據(jù),賦值給key,即key=array[low]。
  • 因?yàn)槟J(rèn)數(shù)組的第一個(gè)數(shù)為基準(zhǔn),所以從后面開始向前搜索(high–),找到第一個(gè)小于key的array[high],就將 array[high] 賦給 array[low],即 array[low] = array[high]。(循環(huán)條件是 array[high] >= key;結(jié)束時(shí) array[high] < key)
  • 此時(shí)從前面開始向后搜索(low++),找到第一個(gè)大于key的array[low],就將 array[low] 賦給 array[high],即 array[high] = array[low]。(循環(huán)條件是 array[low] <= key;結(jié)束時(shí) array[low] > key)
  • 循環(huán) 2-3 步驟,直到 low=high,該位置就是基準(zhǔn)位置。
  • 把基準(zhǔn)數(shù)據(jù)賦給當(dāng)前位置。

2.3、第一趟找到的基準(zhǔn)位置,作為下一趟的分界點(diǎn)。
2.4、遞歸調(diào)用(recursive)分界點(diǎn)前和分界點(diǎn)后的子數(shù)組排序,重復(fù)2.2、2.3、2.4的步驟。
2.5、最終就會(huì)得到排序好的數(shù)組。

3. 動(dòng)態(tài)演示

在這里插入圖片描述

在這里插入圖片描述

4. 完整代碼

三個(gè)函數(shù)
基準(zhǔn)插入函數(shù):int getStandard(int array[],int low,int high)
(返回基準(zhǔn)位置下標(biāo))
遞歸排序函數(shù):void quickSort(int array[],int low,int high)
主函數(shù):int main()

#include <stdio.h>
#include <stdlib.h>

void display(int* array, int size) {
  for (int i = 0; i < size; i++) {
    printf("%d ", array[i]);
  }
  printf("\n");
}

int getStandard(int array[], int i, int j) {
  // 基準(zhǔn)數(shù)據(jù)
  int key = array[i];
  while (i < j) {
    // 因?yàn)槟J(rèn)基準(zhǔn)是從左邊開始,所以從右邊開始比較
    // 當(dāng)隊(duì)尾的元素大于等于基準(zhǔn)數(shù)據(jù) 時(shí),就一直向前挪動(dòng) j 指針
    while (i < j && array[j] >= key) {
      j--;
    }
    // 當(dāng)找到比 array[i] 小的時(shí),就把后面的值 array[j] 賦給它
    if (i < j) {
      array[i] = array[j];
    }
    // 當(dāng)隊(duì)首元素小于等于基準(zhǔn)數(shù)據(jù) 時(shí),就一直向后挪動(dòng) i 指針
    while (i < j && array[i] <= key) {
      i++;
    }
    // 當(dāng)找到比 array[j] 大的時(shí),就把前面的值 array[i] 賦給它
    if (i < j) {
      array[j] = array[i];
    }
  }
  // 跳出循環(huán)時(shí) i 和 j 相等,此時(shí)的 i 或 j 就是 key 的正確索引位置
  // 把基準(zhǔn)數(shù)據(jù)賦給正確位置
  array[i] = key;
  return i;
}

void QuickSort(int array[], int low, int high) {
  // 開始默認(rèn)基準(zhǔn)為 low
  if (low < high) {
    // 分段位置下標(biāo)
    int standard = getStandard(array, low, high);
    // 遞歸調(diào)用排序
    // 左邊排序
    QuickSort(array, low, standard - 1);
    // 右邊排序
    QuickSort(array, standard + 1, high);
  }
}

// 合并到一起快速排序
// void QuickSort(int array[], int low, int high) {
//   if (low < high) {
//     int i  = low;
//     int j  = high;
//     int key = array[i];
//     while (i < j) {
//       while (i < j && array[j] >= key) {
//         j--;
//       }
//       if (i < j) {
//         array[i] = array[j];
//       }
//       while (i < j && array[i] <= key) {
//         i++;
//       }
//       if (i < j) {
//         array[j] = array[i];
//       }
//     }
//     array[i] = key;
//     QuickSort(array, low, i - 1);
//     QuickSort(array, i + 1, high);
//   }
// }

int main() {
  int array[] = {49, 38, 65, 97, 76, 13, 27, 49, 10};
  int size  = sizeof(array) / sizeof(int);

  // 打印數(shù)據(jù)
  printf("%d \n", size);
  QuickSort(array, 0, size - 1);
  display(array, size);

  // int size   = 20;
  // int array[20] = {0};         // 數(shù)組初始化
  // for (int i = 0; i < 10; i++) {    // 數(shù)組個(gè)數(shù)
  //   for (int j = 0; j < size; j++) { // 數(shù)組大小
  //     array[j] = rand() % 1000;  // 隨機(jī)生成數(shù)大小 0~999
  //   }
  //   printf("原來的數(shù)組:");
  //   display(array, size);
  //   QuickSort(array, 0, size - 1);
  //   printf("排序后數(shù)組:");
  //   display(array, size);
  //   printf("\n");
  // }

  return 0;
}

5. 結(jié)果展示

(遞歸調(diào)用,不好展示每次排序結(jié)果)

在這里插入圖片描述

6. 算法分析

時(shí)間復(fù)雜度:

  • 最好: O ( n l o g 2 n ) O(n log_{2} n) O(nlog2​n)
  • 最壞: O ( n 2 ) O(n^2) O(n2)
  • 平均: O ( n l o g 2 n ) O(n log_{2} n) O(nlog2​n)

空間復(fù)雜度: O ( n l o g 2 n ) O(n log_{2} n) O(nlog2​n)

穩(wěn)定性:不穩(wěn)定

到此這篇關(guān)于C/C++實(shí)現(xiàn)快速排序算法的思路及原理解析的文章就介紹到這了,更多相關(guān)C++實(shí)現(xiàn)快速排序算法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Dev-C++中文亂碼問題的解決辦法

    Dev-C++中文亂碼問題的解決辦法

    述Dev-C++是一款非常簡(jiǎn)潔實(shí)用的C/C++集成開發(fā)環(huán)境,因?yàn)楦咧袇⒓痈?jìng)賽的原因我也一直有使用它,下面這篇文章主要給大家介紹了關(guān)于Dev-C++中文亂碼問題的解決辦法,需要的朋友可以參考下
    2023-02-02
  • C++之openFrameworks框架介紹

    C++之openFrameworks框架介紹

    本章我們將介紹一個(gè)非常好用的跨平臺(tái)的 C++開源框架 openFrameworks。它是一個(gè)開源的跨平臺(tái)的C++工具包,方便開發(fā)者創(chuàng)建出一個(gè)更簡(jiǎn)單和直觀的框架,擅長(zhǎng)開發(fā)圖像和動(dòng)畫,感興趣的同學(xué)可以參考一下
    2023-05-05
  • Seesion在C++服務(wù)端的使用方法

    Seesion在C++服務(wù)端的使用方法

    這篇文章主要介紹了Seesion在C++服務(wù)端是怎么使用的?本文給出了解決方案和實(shí)例代碼供大家參考,需要的朋友可以參考下
    2020-02-02
  • C語言代碼實(shí)現(xiàn)掃雷小游戲

    C語言代碼實(shí)現(xiàn)掃雷小游戲

    這篇文章主要為大家詳細(xì)介紹了C語言代碼實(shí)現(xiàn)掃雷小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-02-02
  • Qt中QPixmap、QImage、QPicture、QBitmap四者區(qū)別詳解

    Qt中QPixmap、QImage、QPicture、QBitmap四者區(qū)別詳解

    Qt 提供了四個(gè)類來處理圖像數(shù)據(jù):QImage、QPixmap、QBitmap 和 QPicture,本文就詳細(xì)的介紹一下四者區(qū)別,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • VC打印word,excel文本文件的方法

    VC打印word,excel文本文件的方法

    這篇文章主要介紹了VC打印word,excel文本文件的方法,是VC操作文本文件中非常實(shí)用的技巧,需要的朋友可以參考下
    2014-10-10
  • c++ 頭文件<cwchar>中常見函數(shù)的實(shí)現(xiàn)代碼

    c++ 頭文件<cwchar>中常見函數(shù)的實(shí)現(xiàn)代碼

    本文記錄了c++ 頭文件<cwchar>中常見函數(shù)的實(shí)現(xiàn),本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2023-12-12
  • win32下進(jìn)程間通信(共享內(nèi)存)實(shí)例分析

    win32下進(jìn)程間通信(共享內(nèi)存)實(shí)例分析

    這篇文章主要介紹了win32下進(jìn)程間通信(共享內(nèi)存)實(shí)例分析,對(duì)win32應(yīng)用程序及進(jìn)程的原理做了較為深入的剖析,需要的朋友可以參考下
    2014-07-07
  • 利用Matlab實(shí)現(xiàn)迭代適應(yīng)點(diǎn)算法

    利用Matlab實(shí)現(xiàn)迭代適應(yīng)點(diǎn)算法

    道格拉斯-普克算法(Douglas–Peucker?algorithm,亦稱為拉默-道格拉斯-普克算法、迭代適應(yīng)點(diǎn)算法、分裂與合并算法)是將曲線近似表示為一系列點(diǎn),并減少點(diǎn)的數(shù)量的一種算法。本文將利用Matlab實(shí)現(xiàn)這一算法,需要的可以參考一下
    2022-04-04
  • OpenCV使用BSM統(tǒng)計(jì)視頻中移動(dòng)的對(duì)象

    OpenCV使用BSM統(tǒng)計(jì)視頻中移動(dòng)的對(duì)象

    這篇文章主要為大家詳細(xì)介紹了OpenCV如何使用BackgroundSubstractor(BSM)實(shí)現(xiàn)視頻中移動(dòng)對(duì)象統(tǒng)計(jì)功能,文中的示例代碼講解詳細(xì),需要的可以參考一下
    2023-02-02

最新評(píng)論