java 數(shù)據(jù)結(jié)構(gòu)與算法 (快速排序法)
快速排序法:
顧名思議,快速排序法是實(shí)踐中的一種快速的排序算法,在c++或?qū)ava基本類型的排序中特別有用。它的平均運(yùn)行時(shí)間是0(N log N)。該算法之所以特別快,主要是由于非常精練和高度優(yōu)化的內(nèi)部循環(huán)。
快速排序是對(duì)冒泡法的一種改進(jìn)。通過一趟排序?qū)⒁判虻牡臄?shù)據(jù)分割成獨(dú)立的兩部分,其中一部分的所有數(shù)據(jù)都比另一部分所有的數(shù)據(jù)要小,然后再按此方法對(duì)這兩部分?jǐn)?shù)據(jù)分別進(jìn)行快速排序,整個(gè)排序過程可以遞歸進(jìn)行,以此達(dá)到整個(gè)數(shù)據(jù)變成有序序列。
示意圖:
這里 定義最左邊元素 為left 最右邊元素為right
p 元素的值 就是 2對(duì)應(yīng)的索引 0 加上 5對(duì)應(yīng)的索引 7 之和 除以2 得到 索引為3 對(duì)應(yīng)的元素7
用左邊大于 7的數(shù)跟右邊小于7的數(shù)進(jìn)行 交換位置 一直進(jìn)行 并且 中間的p也要一直變化位置
直到 排完
代碼實(shí)現(xiàn):
import java.util.Arrays; ? public class kuaisu { ? ? public static void main(String[] args) { ? ? ? ? int arrays[]=new int[]{2,9,4,7,3,3,6,5}; ? ? ? ? sort(arrays,0,arrays.length-1); ? ? ? ? System.out.println(Arrays.toString(arrays)); ? ? ? ? }
? public ?static ?void ?sort(int arrays[],int left,int right){ ? ? ? ? int l=left ;//給定下標(biāo) ? ? ? ? int r=right;//給定下標(biāo) ? ? ? ? int temp; //定義一個(gè)變量 作為中間值 交換 左右兩邊的元素位置 ? ? ? ? int pivot=arrays[(left+right)/2];//中間值 ? ? ? ? while(l<r){ ? ? ? ? ? ? //在左邊查找小于中間值得元素 ? ? ? ? ? ? while(arrays[l]<arrays[pivot]){ ? ? ? ? ? ? ? ? l++; ? ? ? ? ? ? ? } ? ? ? ? ? ? //同理在右邊查找大于中間值得元素 ? ? ? ? ? ? while(arrays[r]>arrays[pivot]){ ? ? ? ? ? ? ? ? r--; ? ? ? ? ? ? }//直到左邊元素大于右邊元素就結(jié)束 ? ? ? ? ? ? if(l>=r){ ? ? ? ? ? ? ? ? break; ? ? ? ? ? ? } ? ? ? ? ? ? temp=arrays[l]; ? ? ? ? ? ? arrays[l]=arrays[r]; ? ? ? ? ? ? arrays[r]=temp; ? ? ? ? ? ? //交換完arrays[l]=pivot ? ? ? ? ? ? if(arrays[l]==pivot){ ? ? ? ? ? ? ? ? r--; ? ? ? ? ? ? } ? ? ? ? ? ? if(arrays[r]==pivot){ ? ? ? ? ? ? ? ? l++; ? ? ? ? ? ? } ? ? ? ? ? ? if(r==l){ //要讓左邊元素 往左邊移 右邊元素往右邊移 錯(cuò)開 ? ? ? ? ? ? ? ? l++; ? ? ? ? ? ? ? ? r--; ? ? ? ? ? ? } //對(duì)左邊進(jìn)行遞歸 ? ? ? ? ? ? if(left<r){ ? ? ? ? ? ? ? ? sort(arrays,left,r); ? ? ? ? ? ? }//對(duì)右邊進(jìn)行遞歸 ? ? ? ? ? ? if(right>l){ ? ? ? ? ? ? ? ? sort(arrays,l,right); ? ? ? ? ? ? ? } ? ? ? ? } ? ? } }
控制臺(tái)輸出結(jié)果 如下:
到此這篇關(guān)于java 數(shù)據(jù)結(jié)構(gòu)與算法 (快速排序法)的文章就介紹到這了,更多相關(guān)java 數(shù)據(jù)結(jié)構(gòu)與算法 內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java 如何讀取Excel格式xls、xlsx數(shù)據(jù)工具類
這篇文章主要介紹了Java 如何讀取Excel格式xls、xlsx數(shù)據(jù)工具類的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-09-09SpringBoot添加自定義攔截器的實(shí)現(xiàn)代碼
這篇文章主要介紹了SpringBoot添加自定義攔截器的實(shí)現(xiàn)代碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-09-09springboot 使用poi進(jìn)行數(shù)據(jù)的導(dǎo)出過程詳解
這篇文章主要介紹了springboot 使用poi進(jìn)行數(shù)據(jù)的導(dǎo)出過程詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-09-09java8時(shí)間 yyyyMMddHHmmss格式轉(zhuǎn)為日期的代碼
這篇文章主要介紹了java8時(shí)間 yyyyMMddHHmmss格式轉(zhuǎn)為日期的代碼,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-09-09詳解Java繼承中屬性、方法和對(duì)象的關(guān)系
這篇文章主要幫助大家詳細(xì)介紹了Java繼承中屬性、方法和對(duì)象的關(guān)系,感興趣的朋友可以參考一下2016-03-03全面剖析java 數(shù)據(jù)類型與運(yùn)算符
這篇文章主要介紹了Java基本數(shù)據(jù)類型和運(yùn)算符,結(jié)合實(shí)例形式詳細(xì)分析了java基本數(shù)據(jù)類型、數(shù)據(jù)類型轉(zhuǎn)換、算術(shù)運(yùn)算符、邏輯運(yùn)算符等相關(guān)原理與操作技巧,需要的朋友可以參考下2021-09-09