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(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)
希爾排序也稱遞減增量排序,是對(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-05
springboot的http.server.requests服務(wù)請(qǐng)求流程源碼
這篇文章主要為大家介紹了springboot的http.server.requests服務(wù)請(qǐng)求流程源碼,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-12-12
Windows10系統(tǒng)下修改jar中的文件并重新打包成jar文件然后運(yùn)行的操作步驟
這篇文章主要介紹了Windows10系統(tǒng)下修改jar中的文件并重新打包成jar文件然后運(yùn)行的操作步驟,文中通過(guò)圖文結(jié)合的形式給大家講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2024-08-08
Spring使用aop切面編程時(shí)要給那些類加注解的實(shí)例
在使用切面編程時(shí),通常需要為以下類或組件添加注解來(lái)標(biāo)識(shí)它們,以便 Spring 或其他切面框架能夠正確識(shí)別和處理它們,這篇文章主要介紹了Spring使用aop切面編程時(shí)要給那些類加注解,需要的朋友可以參考下2023-11-11
java多態(tài)的向上轉(zhuǎn)型的概念及實(shí)例分析
在本篇內(nèi)容里小編給大家整理的是一篇關(guān)于java多態(tài)的向上轉(zhuǎn)型的概念及實(shí)例分析,對(duì)此有興趣的朋友們可以跟著學(xué)習(xí)下。2021-05-05
SpringBoot整合Redisson的步驟(單機(jī)版)
Redisson非常適用于分布式鎖,而我們的一項(xiàng)業(yè)務(wù)需要考慮分布式鎖這個(gè)應(yīng)用場(chǎng)景,于是我整合它做一個(gè)初步簡(jiǎn)單的例子(和整合redis一樣)。2021-05-05

