java快速排序和選擇排序?qū)崿F(xiàn)實(shí)例解析
一、快速排序(Quick Sort)
快速排序采用分治法。首先從數(shù)列中挑出一個(gè)元素作為中間值。依次遍歷數(shù)據(jù),所有比中間值小的元素放在左邊,所有比中間值大的元素放在右邊。然后按此方法對(duì)左右兩個(gè)子序列分別進(jìn)行遞歸操作,直到所有數(shù)據(jù)有序。最理想的情況是,每次劃分所選擇的中間數(shù)恰好將當(dāng)前序列幾乎等分(均勻排布),整個(gè)算法的時(shí)間復(fù)雜度為O(n logn)
最壞的情況是,每次所選的中間數(shù)是當(dāng)前序列中的最大或最小元素(正序和逆序都是最壞),整個(gè)排序算法的時(shí)間復(fù)雜度為O(n²)。
平均時(shí)間復(fù)雜度為O(n logn),空間復(fù)雜度為O(logn),是一種不穩(wěn)定的排序算法。
附算法實(shí)現(xiàn)源碼:
//快速排序 template <class T> int Partition(T data[],int left,int right) { T pivot=data[left]; while(left<right) { while(left<right&&data[right]>pivot) right--; data[left]=data[right]; while(left<right&&data[left]<=pivot) left++; data[right]=data[left]; } data[left]=pivot; return left; } template <class T> void QuickSort(T data[],int left,int right) { if(left<right) { int p=Partition(data,left,right); QuickSort(data,left,p-1); QuickSort(data,p+1,right); } }
二、、選擇排序(Selection Sort)
遍歷所有數(shù)據(jù),先在數(shù)據(jù)中找出最大或最小的元素,放到序列的起始;然后再?gòu)挠嘞碌臄?shù)據(jù)中繼續(xù)尋找最大或最小的元素,依次放到序列中直到所有數(shù)據(jù)有序。原始數(shù)據(jù)的排列順序不會(huì)影響程序耗費(fèi)時(shí)間O(n²),相對(duì)費(fèi)時(shí),不適合大量數(shù)據(jù)排序。
平均時(shí)間復(fù)雜度為O(n²),空間復(fù)雜度為O(1),是一種不穩(wěn)定的排序算法。
附算法實(shí)現(xiàn)源碼:
//選擇排序 template <class T> void SelectionSort(T data[],int n) { for(int i=1;i<n;i++) { int k=i-1; for(int j=i;j<n;j++) { if(data[j]<data[k]) { k=j; } } if(k!=i-1) { T t=data[k]; data[k]=data[i-1]; data[i-1]=t; } } }
三、插入排序(Insertion Sort)
將前i個(gè)(初始為1)數(shù)據(jù)假定為有序序列,依次遍歷數(shù)據(jù),將當(dāng)前數(shù)據(jù)插入到前述有序序列的適當(dāng)位置,形成前i+1個(gè)有序序列,依次遍歷完所有數(shù)據(jù),直至序列中所有數(shù)據(jù)有序。數(shù)據(jù)是反序時(shí),耗費(fèi)時(shí)間最長(zhǎng)O(n²);數(shù)據(jù)是正序時(shí),耗費(fèi)時(shí)間最短O(píng)(n)。適用于部分?jǐn)?shù)據(jù)已經(jīng)排好的少量數(shù)據(jù)排序。
平均時(shí)間復(fù)雜度為O(n²),空間復(fù)雜度為O(1),是一種穩(wěn)定的排序算法。
附算法實(shí)現(xiàn)源碼(直接插入+折半插入):
//直接插入排序 template <class T> void InsertionSort(T Data[],int n) { int p,i; for(p=1;p<n;p++) { T temp=Data[p]; i=p-1; while(i>=0&&Data[i]>temp) { Data[i+1]=Data[i]; i--; } Data[i+1]=temp; } } //折半插入排序 template <class T> void BinaryInsertionSort(T Data[],int n) { int left,mid,right,p; for(p=1;p<n;p++) { T temp=Data[p]; left =0; right=n-1; while(left<=right) { mid=(left+right)/2; if(Data[mid]>temp) right=mid-1; else left=mid+1; } for(int i=p-1;i>=left;i--) Data[i+1]=Data[i]; Data[left]=temp; } }
四、希爾排序(Shell Sort)
希爾排序也稱(chēng)遞減增量排序,是對(duì)插入排序的改進(jìn),以犧牲穩(wěn)定性的方法提高效率。基本思路是先將整個(gè)數(shù)據(jù)序列分割成若干子序列分別進(jìn)行直接插入排序,待整個(gè)序列中的記錄基本有序時(shí),再對(duì)全部數(shù)據(jù)進(jìn)行依次直接插入排序,直至所有數(shù)據(jù)有序。希爾排序算法的性能與所選取的分組長(zhǎng)度序列有很大關(guān)系,復(fù)雜度下界為O(n log²n),在中等規(guī)模的數(shù)據(jù)中表現(xiàn)良好。
平均時(shí)間復(fù)雜度為O(n^3/2),空間復(fù)雜度為O(1),是一種不穩(wěn)定的排序算法。
附算法實(shí)現(xiàn)源碼:
//希爾排序 template <class T> void ShellSort(T Data[],int n) { int d=n/2; while(d>=1) { for(int k=0;k<d;k++) { for(int i=k+d;i<n;i+=d) { T temp=Data[i]; int j=i-d; while(j>=k&&Data[j]>temp) { Data[j+d]=Data[j]; j-=d; } Data[j+d]=temp; } } d=d/2; } }
以上就是java快速排序和選擇排序?qū)崿F(xiàn)實(shí)例解析的詳細(xì)內(nèi)容,更多關(guān)于java快速排序選擇排序的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
java ssm框架的controller實(shí)現(xiàn)向頁(yè)面?zhèn)鬟f參數(shù)
這篇文章主要介紹了java ssm框架的controller實(shí)現(xiàn)向頁(yè)面?zhèn)鬟f參數(shù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-05-05springboot的http.server.requests服務(wù)請(qǐng)求流程源碼
這篇文章主要為大家介紹了springboot的http.server.requests服務(wù)請(qǐng)求流程源碼,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-12-12Windows10系統(tǒng)下修改jar中的文件并重新打包成jar文件然后運(yùn)行的操作步驟
這篇文章主要介紹了Windows10系統(tǒng)下修改jar中的文件并重新打包成jar文件然后運(yùn)行的操作步驟,文中通過(guò)圖文結(jié)合的形式給大家講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2024-08-08Spring使用aop切面編程時(shí)要給那些類(lèi)加注解的實(shí)例
在使用切面編程時(shí),通常需要為以下類(lèi)或組件添加注解來(lái)標(biāo)識(shí)它們,以便 Spring 或其他切面框架能夠正確識(shí)別和處理它們,這篇文章主要介紹了Spring使用aop切面編程時(shí)要給那些類(lèi)加注解,需要的朋友可以參考下2023-11-11java多態(tài)的向上轉(zhuǎn)型的概念及實(shí)例分析
在本篇內(nèi)容里小編給大家整理的是一篇關(guān)于java多態(tài)的向上轉(zhuǎn)型的概念及實(shí)例分析,對(duì)此有興趣的朋友們可以跟著學(xué)習(xí)下。2021-05-05SpringBoot整合Redisson的步驟(單機(jī)版)
Redisson非常適用于分布式鎖,而我們的一項(xiàng)業(yè)務(wù)需要考慮分布式鎖這個(gè)應(yīng)用場(chǎng)景,于是我整合它做一個(gè)初步簡(jiǎn)單的例子(和整合redis一樣)。2021-05-05