题目链接:https://pintia.cn/problem-sets/994805342720868352/problems/994805377432928256
题目大意:给出原始序列,以及插入排序或归并排序的某一步,判断是什么排序,并且输出下一步。
分析:对于插入排序,我们看看第二个序列中,已经排好的个数,假设为x,再看看没排好的,但是与原始序列相同的个数,假设为y,如果x+y==n,那么就是插入排序,然后把前(x+1)个数排序,输出就可以了。
对于归并排序,这里并不是真正的归并排序,因为真正的归并排序是把数组分成两半,把左边的完全排列正确后,再排右边的,而不是同时进行,所以我们要同时进行并判断才可以。
#include <bits/stdc++.h>
using namespace std;
#define inf 0x3f3f3f3f
int n, a[110], b[110];
int main() {
scanf("%d", &n);
for(int i = 1; i <= n; i++)
scanf("%d", &a[i]);
for(int i = 1; i <= n; i++)
scanf("%d", &b[i]);
int f = 0;
int cnt = 1, id = 1;
for(int i = 2; i <= n; i++) {
if(b[i] >= b[i - 1]) {
cnt++;
id = i;
} else {
break;
}
}
for(int i = id + 1; i <= n; i++) {
if(a[i] == b[i]) cnt++;
}
if(cnt == n) {
printf("Insertion Sort\n");
sort(b + 1, b + id + 2);
for(int i = 1; i <= n; i++)
printf("%d%s", b[i], i == n ? "\n" : " ");
} else {
printf("Merge Sort\n");
int k = 1, flag = 1;
while(flag) {
flag = 0;
for(int i = 1; i <= n; i++) {
if(a[i] != b[i]) {
flag = 1;
break;
}
}
k <<= 1;
for(int i = 0; i < n / k; i++)
sort(a + i * k + 1, a + (i + 1) * k + 1);
sort(a + n / k * k + 1, a + n + 1);
}
for(int i = 1; i <= n; i++)
printf("%d%s", a[i], i == n ? "\n" : " ");
}
return 0;
}