1035 插入与归并 (25 分)
作者:互联网
原题
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;
}
标签:sort,25,归并,排序,int,cin,100,include,1035 来源: https://www.cnblogs.com/InifiteVictory/p/15674117.html