1. 程式人生 > 遊戲 >FTC或將批准微軟收購動視暴雪 但微軟必須做出讓步

FTC或將批准微軟收購動視暴雪 但微軟必須做出讓步

比較常見的排序方法,見例題:

本題要求實現堆排序中的篩選函式,待排序列的長度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;                          			//插入
}