日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > c/c++ >内容正文

c/c++

快速排序的C++实现(利用二分分治法)

發布時間:2024/9/21 c/c++ 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 快速排序的C++实现(利用二分分治法) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

一、學習要點:
1.先從數列中選取一個數作為基準數。
2.利用區分過程,為這個數確定在排序后數組的位置,區分過程為,比這個數大的數全放到他的右邊,小于或等于這個數的數放到他的左邊;
3.在對左右區間重復第二步,知道個區間只有一個數。
4.如果這個數組有10個數,第二步將執行十次,每次的復雜度為logn,總復雜度為O(nlogn),因為每執行一次區間排序可為數組中一個元素確定該元素在排序后的位置;
注:每走一趟的思維(挖坑填數)如下:
1.i=L;j=R;將基準數挖出形成第一個坑a[i].
2.j–由后向前找比他小的數,直到找到比他小,找到后挖出此數填前一個坑a[i]中。
3.i++由前向后找到比它大的數,找到后也挖出此數填到前一個坑a[j]中。
4.在重復執行2、3兩步,直到i==j,將基準數填入a[i]中。
二、實現代碼:

#include<iostream> using namespace std; //函數聲明 void quicksort(int a[],int l,int r); int main(){return 0; } //函數的定義 void quicksort(int a[],int l,int r){ //遞歸體 if(l<r){int i=l,j=r,x=a[l];while(i<j){while(i<j&a[j]>x){j--;}if(i<j){a[i++]=a[j];}while(i<j&a[i]<x){i++;}if(i<j){a[j--]=a[i]}}a[i]=x;//每次走一趟確定一個;quicksort(a,l,i-1);quicksort(a,i+1,r);} //遞歸頭 //l=r }

三、程序運行結果圖:

四、注意事項:
1.每次走完一趟后要確定一個元素在排序后數組中的位置;
2.利用填坑的思維而不是數組元素的交換(在每走一趟的過程中)
喜歡請點贊 謝謝


具體matlab代碼參考:https://download.csdn.net/download/fyf18845165207/10886708

總結

以上是生活随笔為你收集整理的快速排序的C++实现(利用二分分治法)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。