FTC或將批准微軟收購動視暴雪 但微軟必須做出讓步
阿新 • • 發佈:2022-12-06
比較常見的排序方法,見例題:
本題要求實現堆排序中的篩選函式,待排序列的長度1<=n<=1000。
函式介面定義:
void HeapAdjust( HeapType H, int s, int m);
其中L是待排序表,使排序後的資料從小到大排列。
###型別定義:
typedef int KeyType;
typedef struct {
KeyType *elem; /*elem[0]一般作哨兵或緩衝區*/
int Length;
}SqList;
typedef SqList HeapType;
裁判測試程式樣例:
#include<stdio.h>
#include<stdlib.h>
typedef int KeyType;
typedef struct {
KeyType *elem; /*elem[0]一般作哨兵或緩衝區*/
int Length;
}SqList;
typedef SqList HeapType;
void CreatSqListHeapType *L);/*待排序列建立,由裁判實現,細節不表*/
void HeapAdjust( HeapType H, int s, int m);
void HeapSort( HeapType H);
int main()
{
HeapType L;
int i;
CreatSqList(&L);
HeapSort(L);
for(i=1;i<=L.Length;i++)
{
printf("%d ",L.elem[i]);
}
return 0;
}
void HeapSort( HeapType H)
{ /*堆順序表H進行堆排序*/
int i; KeyType rc;
/*建立初始堆*/
for( i=H.Length/2;i>0; i--)
{
HeapAdjust(H, i, H.Length);
}
for(i=H.Length;i>1;i--)
{
rc=H.elem[1];
H.elem[1]=H.elem[i];
H.elem[i]=rc;
HeapAdjust(H, 1, i-1);
}
}
/*你的程式碼將被嵌在這裡 */
輸入樣例:
第一行整數表示參與排序的關鍵字個數。第二行是關鍵字值 例如:
10
5 2 4 1 8 9 10 12 3 6
輸出樣例:
輸出由小到大的有序序列,每一個關鍵字之間由空格隔開,最後一個關鍵字後有一個空格。
1 2 3 4 5 6 8 9 10 12
程式碼如下:
void HeapAdjust( HeapType H, int s, int m){ //假設r[s+1..m]已經是堆,將r[s..m]調整為以r[s]為根的大根堆 KeyType rc; int j; rc=H.elem[s]; for(j=2*s;j<=m;j*=2) { //沿key較大的孩子結點向下篩選 if(j<m&&H.elem[j]<H.elem[j+1]) ++j; //j為key較大的記錄的下標 if(rc>=H.elem[j]) break; //rc應插入在位置s上 H.elem[s]=H.elem[j]; s=j; } H.elem[s]=rc; //插入 }