PAT乙級1035 插入與歸併(C語言)

2021-08-26 18:02:51 字數 809 閱讀 2749

/*

* 1. 插入排序的重要特徵:

* 未排序部分和初始序列一定相同;

* 2. 歸併排序的重要特徵:

* 末尾不足數量的子串行同樣需要排序;

* 3. 利用 qsort() 函式,對部分元素的排序;

* 4. 顯然 是否為插入排序 更容易判斷,將其作為判斷排序型別的切入點;

*/#include

#include

int cmp(const

void *a,const

void *b)

int main()

}int cnt_order = 1;//有序的數量

for (int i = 0; arr[1][i] <= arr[1][i+1] && i < n - 1; i++)

int isinsert = 1;//是否為插入排序

for (int i = cnt_order; i < n; i++)

} if (isinsert) else

}k *= 2;//有序子串行的元素個數

int i;

for (i = 0; i < n / k; i++)

qsort(arr[0]+ i * k, n - i * k, sizeof(int), cmp);//對末尾 不足有序子串行數量的元素排序 }}

for(int i = 0; i < n-1; i++)

printf("%d\n", arr[0][n-1]);

return

0;}

PAT 乙級 1035 插入與歸併

1.題目描述 根據維基百科的定義 插入排序是迭代演算法,逐一獲得輸入資料,逐步產生有序的輸出序列。每步迭代中,演算法從輸入序列中取出一元素,將之插入有序序列中正確的位置。如此迭代直到全部元素有序。歸併排序進行如下迭代操作 首先將原始序列看成n個只包含1個元素的有序子串行,然後每次迭代歸併兩個相鄰的有...

PAT乙級 1035 插入與歸併

根據維基百科的定義 插入排序是迭代演算法,逐一獲得輸入資料,逐步產生有序的輸出序列。每步迭代中,演算法從輸入序列中取出一元素,將之插入有序序列中正確的位置。如此迭代直到全部元素有序。歸併排序進行如下迭代操作 首先將原始序列看成 n 個只包含 1 個元素的有序子串行,然後每次迭代歸併兩個相鄰的有序子串...

PAT乙級 1035插入與歸併

根據維基百科的定義 現給定原始序列和由某排序演算法產生的中間序列,請你判斷該演算法究竟是哪種排序演算法?輸入在第一行給出正整數 n 100 隨後一行給出原始序列的 n 個整數 最後一行給出由某排序演算法產生的中間序列。這裡假設排序的目標序列是公升序。數字間以空格分隔。首先在第 1 行中輸出inser...