PAT乙級刷題之路1035 插入與歸併 25分

2021-10-01 19:46:20 字數 2135 閱讀 1928

根據維基百科的定義:

插入排序是迭代演算法,逐一獲得輸入資料,逐步產生有序的輸出序列。每步迭代中,演算法從輸入序列中取出一元素,將之插入有序序列中正確的位置。如此迭代直到全部元素有序。

歸併排序進行如下迭代操作:首先將原始序列看成 n 個只包含 1 個元素的有序子串行,然後每次迭代歸併兩個相鄰的有序子串行,直到最後只剩下 1 個有序的序列。

現給定原始序列和由某排序演算法產生的中間序列,請你判斷該演算法究竟是哪種排序演算法?

輸入格式:

輸入在第一行給出正整數 n (≤100);隨後一行給出原始序列的 n 個整數;最後一行給出由某排序演算法產生的中間序列。這裡假設排序的目標序列是公升序。數字間以空格分隔。

輸出格式:

首先在第 1 行中輸出insertion sort表示插入排序、或merge sort表示歸併排序;然後在第 2 行中輸出用該排序演算法再迭代一輪的結果序列。題目保證每組測試的結果是唯一的。數字間以空格分隔,且行首尾不得有多餘空格。

輸入樣例 1:

103 1 2 8 7 5 9 4 6 0

1 2 3 7 8 5 9 4 6 0

輸出樣例 1:

insertion sort

1 2 3 5 7 8 9 4 6 0

輸入樣例 2:

103 1 2 8 7 5 9 4 0 6

1 3 2 8 5 7 4 9 0 6

輸出樣例 2:

merge sort

1 2 3 8 4 5 7 9 0 6

其實把資料結構的**搬過來就可以了,判斷給出的中間步驟是不是插入或歸併排序中的中間步驟。

#include

#include

void

printa

(int a,

int n)

//輸出下一步

}int

issamearr

(int a,

int c,

int n)

//比較結果是否相同

void

copyarr

(int a,

int b,

int n)

//因為要經歷兩次排序故用兩個陣列

void

read

(int a,

int b,

int n)

//讀入資料

for(i=

0;ivoid

insertionsort

(int a,

int b,

int n)

//插入排序,邊插入邊比較

a[i]

= tmp;if(

issamearr

(a, b, n))if

(flag==1)

}}void

merge

(int a,

int tmpa,

int l,

int r,

int rightend)

while

(l <= leftend)

tmpa[tmp++

]= a[l++];

while

(r <= rightend)

tmpa[tmp++

]= a[r++];

for(i=

0;i, rightend--

) a[rightend]

= tmpa[rightend];}

void

merge_pass

(int a,

int tmpa,

int n,

int length)

void

merge_sort

(int a,

int b,

int n)

//歸併排序,邊歸併邊比較

if(flag2 ==1)

merge_pass

(tmpa, a, n, length)

; length *=2

;if(issamearr

(a, b, n))if

(flag ==1)

}free

(tmpa);}

}int

main()

PAT 乙級 1035 插入與歸併

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

PAT乙級 1035 插入與歸併

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

PAT乙級 1035插入與歸併

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