https://pintia.cn/problem-sets/994805260223102976/problems/994805286714327040
前面看的柳大佬的,伤脑筋,我以为要会插入排序和归并排序才能做出来,其实不用,了解原理就可以了。
说一下我与大佬稍微不同的地方。对归并排序再迭代一轮的判断。
对整个中间序列,通过判断后一个元素大于前一个元素,找出最小子区间。
#include <iostream> #include <algorithm> using namespace std; int main(){ int n,a[100],b[100],i,j; cin>>n; for(int i=0;i<n;i++) cin>>a[i]; for(int i=0;i<n;i++) cin>>b[i]; for (i = 0; i < n-1&&b[i]<=b[i+1]; i++); for (j = i+1; j < n&&b[j]==a[j]; j++); //如果符合前面按顺序,后面与原数据全部相同 if(j==n){ cout<<"Insertion Sort"<<endl; sort(a,a+i+2); }else{ cout<<"Merge Sort"<<endl; //判断归并的子区间的大小 int min=100,temp=0; for (i = 1; i < n; i++) { while(b[i-1]<b[i]) i++; temp=i-temp;//子区间的长度 if(temp<min) min=temp; } int k=min*2; for(j=0; j<n/k; j++) sort(a+j*k,a+(j+1)*k); sort(a+n/k*k,a+n); } for (int i = 0; i < n; i++) { if(i!=0) printf(" "); cout<<a[i]; } return 0; }
大佬代码:
#include <iostream> #include <algorithm> using namespace std; int main() { int n, a[100], b[100], i, j; cin >> n; for (int i = 0; i < n; i++) cin >> a[i]; for (int i = 0; i < n; i++) cin >> b[i]; for (i = 0; i < n - 1 && b[i] <= b[i + 1]; i++); for (j = i + 1; a[j] == b[j] && j < n; j++); if (j == n) { cout << "Insertion Sort" << endl; sort(a, a + i + 2); } else { cout << "Merge Sort" << endl; //这里没看懂 int k = 1, flag = 1; while(flag) { flag = 0; for (i = 0; i < n; i++) { if (a[i] != b[i]) flag = 1; } k = k * 2; for (i = 0; i < n / k; i++) sort(a + i * k, a + (i + 1) * k); sort(a + n / k * k, a + n); } } for (j = 0; j < n; j++) { if (j != 0) printf(" "); printf("%d", a[j]); } return 0; }
sort函数包含在头文件为#include<algorithm>的c++标准库中,调用标准库里的排序方法可以实现对数据的排序。
void sort (RandomAccessIterator first, RandomAccessIterator last, Compare comp);
#include<iostream> #include<algorithm> using namespace std; bool cmp(int a,int b); main(){ //sort函数第三个参数自己定义,实现从大到小 int a[]={45,12,34,77,90,11,2,4,5,55}; sort(a,a+10,cmp); for(int i=0;i<10;i++) cout<<a[i]<<" "; } //自定义函数 bool cmp(int a,int b){ return a>b; }