【算法笔记】B1035 插入与归并

1035 插入与归并 (25 分)

根据维基百科的定义:

插入排序是迭代算法,逐一获得输入数据,逐步产生有序的输出序列。每步迭代中,算法从输入序列中取出一元素,将之插入有序序列中正确的位置。如此迭代直到全部元素有序。

归并排序进行如下迭代操作:首先将原始序列看成 N 个只包含 1 个元素的有序子序列,然后每次迭代归并两个相邻的有序子序列,直到最后只剩下 1 个有序的序列。

现给定原始序列和由某排序算法产生的中间序列,请你判断该算法究竟是哪种排序算法?

输入格式:

输入在第一行给出正整数 N (≤100);随后一行给出原始序列的 N 个整数;最后一行给出由某排序算法产生的中间序列。这里假设排序的目标序列是升序。数字间以空格分隔。

输出格式:

首先在第 1 行中输出Insertion Sort表示插入排序、或Merge Sort表示归并排序;然后在第 2 行中输出用该排序算法再迭代一轮的结果序列。题目保证每组测试的结果是唯一的。数字间以空格分隔,且行首尾不得有多余空格。

输入样例 1:

10
3 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:

10
3 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

思路:

只需要判断是否是插入排序,如果不是插入排序必然是归并排序。

输出下一次迭代的方法是设置一个flag位,先判断排序是否是目标序列,不管是不是都再迭代一次,最后根据flag判断继续迭代还是终止循环。

codes:

 1 #include<iostream>
 2 #include<algorithm>
 3 using namespace std;
 4 const int maxn = 101;
 5 int ori[maxn], tempOri[maxn], mid[maxn];
 6 int n;
 7 void print(int a[]){
 8     for(int i = 0; i < n; i++){
 9         cout<<a[i];
10         if(i < n - 1) cout<<" ";
11     }
12 }
13 bool isSame(int a[], int b[]){
14     for(int i = 0; i < n; i++){
15         if(a[i] != b[i]) return false;
16     }
17     return true;
18 }
19 bool insertSort(){
20     for(int i = 1; i < n; i++){
21         bool flag = false;
22         if(i != 1 && isSame(tempOri,mid)) flag = true;
23         int t = tempOri[i], j = i;
24         for(j = i - 1; j >= 0, tempOri[j] > t; j--)
25             tempOri[j + 1] = tempOri[j];
26         tempOri[j + 1] = t;
27         if(flag) return true;
28     }
29     return false;
30 }
31 void mergeSort(){
32     bool flag = false;
33     for(int step = 2; step / 2 < n; step *= 2){
34         if(step!=2 && isSame(tempOri,mid)) flag = true;
35         for(int i = 0; i < n; i += step){
36             sort(tempOri + i, tempOri + min(i + step, n));
37         }
38         if(flag) break;
39     }
40  }
41 int main(){
42     cin>>n;
43     for(int i = 0; i < n; i++){
44         cin>>ori[i];
45         tempOri[i] = ori[i];
46     }
47     for(int i = 0; i < n; i++){
48         cin>>mid[i];
49     }
50     if(insertSort()){
51         cout<<"Insertion Sort"<<endl;
52         print(tempOri);
53     }else{
54         for(int i = 0; i < n; i++){
55             tempOri[i] = ori[i];
56         }
57         mergeSort();
58         cout<<"Merge Sort"<<endl;
59         print(tempOri);
60     }
61     return 0;
62 }
原文地址:https://www.cnblogs.com/chunlinn/p/10598322.html