PAT乙級 1035 插入與歸併 25

2021-08-08 04:39:46 字數 555 閱讀 3966

思路很簡單 實現兩個排序 然後比較即可 注意,題目裡的「一輪」排序 在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...