**
根據維基百科的定義:
插入排序是迭代演算法,逐一獲得輸入資料,逐步產生有序的輸出序列。每步迭代中,演算法從輸入序列中取出一元素,將之插入有序序列中正確的位置。如此迭代直到全部元素有序。
歸併排序進行如下迭代操作:首先將原始序列看成 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
本部落格就不談思路了,有很多博主寫的很清楚。
**中,最開始將兩列數字存入到兩個列表中
plist =
[int
(i)for i in
input()
.split()]
alist =
[int
(i)for i in
input()
.split(
)]
這裡最開始是直接存為字串列表,但在pat中出現了三個執行超時;
然後檢視了其他博主的文章後,將其全部轉換為整型,超時的測試點通過;在網上搜尋了一下關於python3字串和整型資料的執行效率,沒有發現有價值的內容,所以寫此作為記錄。
完整**如下:
def
insertionsort
(lst, lst2)
: flag =
0for q in
range(1
,len
(lst)):
tmp = lst[
:q+1
] tmp.sort(
) tmp.extend(lst[q+1:
])if flag ==1:
return tmp
if tmp == lst2:
flag =
1return
false
defmergingsort
(lst, lst2)
: flag =
0 llst =
[[a]
for a in lst]
while
len(lst)
>1:
tmp =
for s in
range(0
,len
(llst),2
):try:
llst[s]
.extend(llst[s +1]
))except:)
llst = tmp
for k in tmp:
k.sort(
) t*** = tmp
result =
for t in t***:
result.extend(t)
result2 =
for j in result:
if flag ==1:
return result
if result == lst2:
flag =
1n =
int(
input()
)plist =
[int
(i)for i in
input()
.split()]
alist =
[int
(i)for i in
input()
.split()]
insert = insertionsort(plist, alist)
if insert:
print
('insertion sort'
)for i in
range
(len
(insert)-1
):print
(insert[i]
,end=
' ')
print
(insert[
len(insert)-1
],end='')
else
:print
('merge sort'
) merge = mergingsort(plist, alist)
for i in
range
(len
(merge)-1
):print
(merge[i]
, end=
' ')
print
(merge[
len(merge)-1
], end=
'')
PAT 乙級 1035 插入與歸併
1.題目描述 根據維基百科的定義 插入排序是迭代演算法,逐一獲得輸入資料,逐步產生有序的輸出序列。每步迭代中,演算法從輸入序列中取出一元素,將之插入有序序列中正確的位置。如此迭代直到全部元素有序。歸併排序進行如下迭代操作 首先將原始序列看成n個只包含1個元素的有序子串行,然後每次迭代歸併兩個相鄰的有...
PAT乙級 1035 插入與歸併
根據維基百科的定義 插入排序是迭代演算法,逐一獲得輸入資料,逐步產生有序的輸出序列。每步迭代中,演算法從輸入序列中取出一元素,將之插入有序序列中正確的位置。如此迭代直到全部元素有序。歸併排序進行如下迭代操作 首先將原始序列看成 n 個只包含 1 個元素的有序子串行,然後每次迭代歸併兩個相鄰的有序子串...
PAT乙級 1035插入與歸併
根據維基百科的定義 現給定原始序列和由某排序演算法產生的中間序列,請你判斷該演算法究竟是哪種排序演算法?輸入在第一行給出正整數 n 100 隨後一行給出原始序列的 n 個整數 最後一行給出由某排序演算法產生的中間序列。這裡假設排序的目標序列是公升序。數字間以空格分隔。首先在第 1 行中輸出inser...