思路很簡單 實現兩個排序 然後比較即可 注意,題目裡的「一輪」排序 在merge中是指merge的size變為原來的兩倍;還有臨時陣列開大一點,不然最後幾個會有段錯誤
//pat-1-1035
#include #include #include #include using namespace std;
int f_insert=0;
int f_merge=0;
int f=0;
int s1[1000]=;
int result[1000]=;
int temarray[1000]=;
int comp(int s0,int s1,int n)
s[j]=temp;
if (f_insert==1&&!comp(s, s1, n)&&f==0)
for (int i=0; i>s1[i];
}insertion_sort(s0, n);
merge_sort(s2, n);
if (f_insert) {
cout<<"insertion sort"<
PAT 乙級 1035 插入與歸併
1.題目描述 根據維基百科的定義 插入排序是迭代演算法,逐一獲得輸入資料,逐步產生有序的輸出序列。每步迭代中,演算法從輸入序列中取出一元素,將之插入有序序列中正確的位置。如此迭代直到全部元素有序。歸併排序進行如下迭代操作 首先將原始序列看成n個只包含1個元素的有序子串行,然後每次迭代歸併兩個相鄰的有...
PAT乙級 1035 插入與歸併
根據維基百科的定義 插入排序是迭代演算法,逐一獲得輸入資料,逐步產生有序的輸出序列。每步迭代中,演算法從輸入序列中取出一元素,將之插入有序序列中正確的位置。如此迭代直到全部元素有序。歸併排序進行如下迭代操作 首先將原始序列看成 n 個只包含 1 個元素的有序子串行,然後每次迭代歸併兩個相鄰的有序子串...
PAT乙級 1035插入與歸併
根據維基百科的定義 現給定原始序列和由某排序演算法產生的中間序列,請你判斷該演算法究竟是哪種排序演算法?輸入在第一行給出正整數 n 100 隨後一行給出原始序列的 n 個整數 最後一行給出由某排序演算法產生的中間序列。這裡假設排序的目標序列是公升序。數字間以空格分隔。首先在第 1 行中輸出inser...