C語(yǔ)言數(shù)據(jù)結(jié)構(gòu) 快速排序?qū)嵗斀?/h1>
更新時(shí)間:2017年08月02日 15:53:46 投稿:lqh
這篇文章主要介紹了C語(yǔ)言數(shù)據(jù)結(jié)構(gòu) 快速排序?qū)嵗斀獾南嚓P(guān)資料,快速排序采用分治的思想,兩邊數(shù)據(jù)進(jìn)行排序,需要的朋友可以參考下
C語(yǔ)言數(shù)據(jù)結(jié)構(gòu) 快速排序?qū)嵗斀?/strong>
一、快速排序簡(jiǎn)介
快速排序采用分治的思想,第一趟先將一串?dāng)?shù)字分為兩部分,第一部分的數(shù)值都比第二部分要小,然后按照這種方法,依次對(duì)兩邊的數(shù)據(jù)進(jìn)行排序。
二、代碼實(shí)現(xiàn)
#include <stdio.h>
/* 將兩個(gè)數(shù)據(jù)交換 */
void swap(int* Ina , int* Inb)
{
int temp = *Ina;
*Ina = *Inb;
*Inb = temp;
}
/* 進(jìn)行一趟的快速排序,把一個(gè)序列分為兩個(gè)部分 */
int getPartion(int* InArry,int InBegin,int InEnd)
{
/* 剛開(kāi)始的分隔線是第一個(gè) */
int part = InBegin;
int index = 0;
if(InEnd >= InBegin)
{
part = InBegin;
for(index = InBegin+1; index <= InEnd; index++)
{
if(InArry[InBegin] >= InArry[index])
{
/* 交換位置 */
swap(&InArry[part+1],&InArry[index]);
part++;
}
}
/* 把第一個(gè)數(shù)放到part處去 */
swap(&InArry[InBegin],&InArry[part]);
return part;
}
}
/* 快速排序函數(shù)
* InArry:輸入的數(shù)組
* InBegin:數(shù)組的開(kāi)始
* InEnd:數(shù)組的結(jié)束
*/
void quickSort(int* InArry,int InBegin,int InEnd)
{
if(InArry == NULL || InEnd <= InBegin)
{
return;
}
int part = 0;
part = getPartion(InArry,InBegin,InEnd);
/* 遞歸調(diào)用 */
quickSort(InArry,0,part-1);
quickSort(InArry,part+1,InEnd);
}
int main()
{
int a[] = {49,38,65,97,76,13,27};
int index = 0;
int len = sizeof(a)/sizeof(int);
/* 先遍歷打印一下數(shù)組的元素 */
for(index = 0; index < len; index++)
{
printf("%d ",a[index]);
}
printf("\n");
/* 調(diào)用快速排序函數(shù) */
quickSort(a,0,len-1);
/* 再遍歷打印一下數(shù)組的元素 */
for(index = 0; index < len; index++)
{
printf("%d ",a[index]);
}
printf("\n");
return 0;
}
以上就是使用C語(yǔ)言數(shù)據(jù)結(jié)構(gòu) 快速排序的實(shí)例詳解,如有疑問(wèn)請(qǐng)留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站 的支持!
您可能感興趣的文章:- c語(yǔ)言快速排序算法示例代碼分享
- C語(yǔ)言實(shí)現(xiàn)選擇排序、冒泡排序和快速排序的代碼示例
- 用c語(yǔ)言實(shí)現(xiàn)冒泡排序,選擇排序,快速排序
- C語(yǔ)言簡(jiǎn)單實(shí)現(xiàn)快速排序
- C語(yǔ)言快速排序函數(shù)用法(qsort)
- C語(yǔ)言實(shí)現(xiàn)快速排序算法
- C語(yǔ)言的冒泡排序和快速排序算法使用實(shí)例
- C語(yǔ)言中快速排序和插入排序優(yōu)化的實(shí)現(xiàn)
- C語(yǔ)言實(shí)現(xiàn)快速排序
- C語(yǔ)言實(shí)現(xiàn)快速排序算法實(shí)例
相關(guān)文章
-
你必須知道的C語(yǔ)言預(yù)處理的問(wèn)題詳解
本篇文章介紹了,你必須知道的C語(yǔ)言預(yù)處理的問(wèn)題。需要的朋友參考下 2013-05-05
-
c++中priority_queue模擬的實(shí)現(xiàn)
priority_queue是C++標(biāo)準(zhǔn)庫(kù)中的一個(gè)容器適配器,用于實(shí)現(xiàn)優(yōu)先隊(duì)列的數(shù)據(jù)結(jié)構(gòu),本文主要介紹了c++中priority_queue模擬的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下 2024-09-09
-
C語(yǔ)言實(shí)現(xiàn)飛機(jī)訂票系統(tǒng)的完整代碼
為了免去在窗口排隊(duì)買票的麻煩,飛機(jī)訂票系統(tǒng)應(yīng)運(yùn)而生,下面這篇文章主要給大家介紹了關(guān)于C語(yǔ)言實(shí)現(xiàn)飛機(jī)訂票系統(tǒng)的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下 2022-06-06
-
C語(yǔ)言實(shí)現(xiàn)學(xué)生信息管理系統(tǒng)(鏈表)
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)學(xué)生信息管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下 2022-06-06
-
C++運(yùn)行時(shí)類型識(shí)別與轉(zhuǎn)換實(shí)現(xiàn)方法
運(yùn)行時(shí)類型識(shí)別可能被認(rèn)為是C++中一個(gè)”次要“的特征,當(dāng)程序員在編程過(guò)程中陷入非常困難的境地時(shí),實(shí)用主義將會(huì)幫助他走出困境 2022-10-10
最新評(píng)論
C語(yǔ)言數(shù)據(jù)結(jié)構(gòu) 快速排序?qū)嵗斀?/strong>
一、快速排序簡(jiǎn)介
快速排序采用分治的思想,第一趟先將一串?dāng)?shù)字分為兩部分,第一部分的數(shù)值都比第二部分要小,然后按照這種方法,依次對(duì)兩邊的數(shù)據(jù)進(jìn)行排序。
二、代碼實(shí)現(xiàn)
#include <stdio.h>
/* 將兩個(gè)數(shù)據(jù)交換 */
void swap(int* Ina , int* Inb)
{
int temp = *Ina;
*Ina = *Inb;
*Inb = temp;
}
/* 進(jìn)行一趟的快速排序,把一個(gè)序列分為兩個(gè)部分 */
int getPartion(int* InArry,int InBegin,int InEnd)
{
/* 剛開(kāi)始的分隔線是第一個(gè) */
int part = InBegin;
int index = 0;
if(InEnd >= InBegin)
{
part = InBegin;
for(index = InBegin+1; index <= InEnd; index++)
{
if(InArry[InBegin] >= InArry[index])
{
/* 交換位置 */
swap(&InArry[part+1],&InArry[index]);
part++;
}
}
/* 把第一個(gè)數(shù)放到part處去 */
swap(&InArry[InBegin],&InArry[part]);
return part;
}
}
/* 快速排序函數(shù)
* InArry:輸入的數(shù)組
* InBegin:數(shù)組的開(kāi)始
* InEnd:數(shù)組的結(jié)束
*/
void quickSort(int* InArry,int InBegin,int InEnd)
{
if(InArry == NULL || InEnd <= InBegin)
{
return;
}
int part = 0;
part = getPartion(InArry,InBegin,InEnd);
/* 遞歸調(diào)用 */
quickSort(InArry,0,part-1);
quickSort(InArry,part+1,InEnd);
}
int main()
{
int a[] = {49,38,65,97,76,13,27};
int index = 0;
int len = sizeof(a)/sizeof(int);
/* 先遍歷打印一下數(shù)組的元素 */
for(index = 0; index < len; index++)
{
printf("%d ",a[index]);
}
printf("\n");
/* 調(diào)用快速排序函數(shù) */
quickSort(a,0,len-1);
/* 再遍歷打印一下數(shù)組的元素 */
for(index = 0; index < len; index++)
{
printf("%d ",a[index]);
}
printf("\n");
return 0;
}
以上就是使用C語(yǔ)言數(shù)據(jù)結(jié)構(gòu) 快速排序的實(shí)例詳解,如有疑問(wèn)請(qǐng)留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站 的支持!
- c語(yǔ)言快速排序算法示例代碼分享
- C語(yǔ)言實(shí)現(xiàn)選擇排序、冒泡排序和快速排序的代碼示例
- 用c語(yǔ)言實(shí)現(xiàn)冒泡排序,選擇排序,快速排序
- C語(yǔ)言簡(jiǎn)單實(shí)現(xiàn)快速排序
- C語(yǔ)言快速排序函數(shù)用法(qsort)
- C語(yǔ)言實(shí)現(xiàn)快速排序算法
- C語(yǔ)言的冒泡排序和快速排序算法使用實(shí)例
- C語(yǔ)言中快速排序和插入排序優(yōu)化的實(shí)現(xiàn)
- C語(yǔ)言實(shí)現(xiàn)快速排序
- C語(yǔ)言實(shí)現(xiàn)快速排序算法實(shí)例
相關(guān)文章
你必須知道的C語(yǔ)言預(yù)處理的問(wèn)題詳解
本篇文章介紹了,你必須知道的C語(yǔ)言預(yù)處理的問(wèn)題。需要的朋友參考下2013-05-05
c++中priority_queue模擬的實(shí)現(xiàn)
priority_queue是C++標(biāo)準(zhǔn)庫(kù)中的一個(gè)容器適配器,用于實(shí)現(xiàn)優(yōu)先隊(duì)列的數(shù)據(jù)結(jié)構(gòu),本文主要介紹了c++中priority_queue模擬的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下2024-09-09
C語(yǔ)言實(shí)現(xiàn)飛機(jī)訂票系統(tǒng)的完整代碼
為了免去在窗口排隊(duì)買票的麻煩,飛機(jī)訂票系統(tǒng)應(yīng)運(yùn)而生,下面這篇文章主要給大家介紹了關(guān)于C語(yǔ)言實(shí)現(xiàn)飛機(jī)訂票系統(tǒng)的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-06-06
C語(yǔ)言實(shí)現(xiàn)學(xué)生信息管理系統(tǒng)(鏈表)
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)學(xué)生信息管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-06-06
C++運(yùn)行時(shí)類型識(shí)別與轉(zhuǎn)換實(shí)現(xiàn)方法
運(yùn)行時(shí)類型識(shí)別可能被認(rèn)為是C++中一個(gè)”次要“的特征,當(dāng)程序員在編程過(guò)程中陷入非常困難的境地時(shí),實(shí)用主義將會(huì)幫助他走出困境2022-10-10

