/*
* 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...