項目1.3 快速排序


/*   

* Copyright (c) 2015, 煙台大學計算機與控制工程學院   

* All rights reserved.   

* 文件名稱:main.cpp

* 作者:張志康  

* 完成日期:2015年12月14日   

* 版本號:vc++6.0   

*   

* 問題描述:

* 輸入描述:

* 程序輸出:

 */ 

代碼:

//1.以第1個元素作為基准

#include <stdio.h>
#define MaxSize 20
typedef int KeyType; //定義關鍵字類型
typedef char InfoType[10];
typedef struct //記錄類型
{
KeyType key; //關鍵字項
InfoType data; //其他數據項,類型為InfoType
} RecType; //排序的記錄類型定義
void QuickSort(RecType R[],int s,int t) //對R[s]至R[t]的元素進行快速排序
{
int i=s,j=t;
RecType tmp;
if (s<t) //區間內至少存在兩個元素的情況
{
tmp=R[s]; //用區間的第1個記錄作為基准
while (i!=j) //從區間兩端交替向中間掃描,直至i=j為止
{
while (j>i && R[j].key>=tmp.key)
j--; //從右向左掃描,找第1個小於tmp.key的R[j]
R[i]=R[j]; //找到這樣的R[j],R[i]"R[j]交換
while (i<j && R[i].key<=tmp.key)
i++; //從左向右掃描,找第1個大於tmp.key的記錄R[i]
R[j]=R[i]; //找到這樣的R[i],R[i]"R[j]交換
}
R[i]=tmp;
QuickSort(R,s,i-1); //對左區間遞歸排序
QuickSort(R,i+1,t); //對右區間遞歸排序
}
}
int main()
{
int i,n=10;
RecType R[MaxSize];
KeyType a[]= {6,8,7,9,0,1,3,2,4,5};
for (i=0; i<n; i++)
R[i].key=a[i];
printf("排序前:");
for (i=0; i<n; i++)
printf("%d ",R[i].key);
printf("\n");
QuickSort(R,0,n-1);
printf("排序后:");
for (i=0; i<n; i++)
printf("%d ",R[i].key);
printf("\n");
return 0;
}


運行結果:

2.以中間位置的元素作為基准

#include <stdio.h>
#define MaxSize 20
typedef int KeyType; //定義關鍵字類型
typedef char InfoType[10];
typedef struct //記錄類型
{
KeyType key; //關鍵字項
InfoType data; //其他數據項,類型為InfoType
} RecType; //排序的記錄類型定義
void QuickSort1(RecType R[],int s,int t) //對R[s]至R[t]的元素進行快速排序
{
int i=s,j=t;
KeyType pivot;
RecType tmp;
pivot = R[(s+t)/2].key; //用區間的中間位置的元素作為關鍵字
if (s<t) //區間內至少存在兩個元素的情況
{
while (i!=j) //從區間兩端交替向中間掃描,直至i=j為止
{
while (j>i && R[j].key>pivot)
j--; //從右向左掃描,找第1個小於基准的R[j]
while (i<j && R[i].key<pivot)
i++; //從左向右掃描,找第1個大於基准記錄R[i]
if(i<j) //將前后的兩個失序元素進行交換
{
tmp=R[i];
R[i]=R[j];
R[j]=tmp;
}
}
QuickSort1(R,s,i-1); //對左區間遞歸排序
QuickSort1(R,j+1,t); //對右區間遞歸排序
}
}
int main()
{
int i,n=10;
RecType R[MaxSize];
KeyType a[]= {6,8,7,9,0,1,3,2,4,5};
for (i=0; i<n; i++)
R[i].key=a[i];
printf("排序前:");
for (i=0; i<n; i++)
printf("%d ",R[i].key);
printf("\n");
QuickSort1(R,0,n-1);
printf("排序后:");
for (i=0; i<n; i++)
printf("%d ",R[i].key);
printf("\n");
return 0;
}


運行結果:


注意!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系我们删除。



 
粤ICP备14056181号  © 2014-2021 ITdaan.com