判断插入排序很好判断,不是的话那就是归并排序了。

由于归并排序区间是2、4、8开始递增的,所以要判断给出的归并排序执行到哪一步,就要k从2开始枚举。

然后再对每个子区间进行一下sort即可。

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <string.h>
#include <cmath>
using namespace std;
const int maxn=;
int num1[maxn],num2[maxn]; int main()
{
int n;
scanf("%d",&n);
for(int i=;i<n;i++)
scanf("%d",&num1[i]);
for(int i=;i<n;i++)
scanf("%d",&num2[i]);
int p,idx;
for(idx=;num2[idx]<=num2[idx+];idx++);
p=idx+;
for(;num2[p]==num1[p] && p<n;p++);
//printf("idx:%d p:%d\n",idx,p);
if(p==n){
sort(num2,num2+idx+);
printf("Insertion Sort\n");
printf("%d",num2[]);
for(int i=;i<n;i++){
printf(" %d",num2[i]);
}
}
else{
int k;
bool flag=true;
for(k=;k<=n;k=(k<<)){
for(int i=;i<n;i+=k){
for(int j=i;j<i+k-&&j<n-;j++){
if(num2[j]>num2[j+]){
flag=false;
break;
}
}
if(!flag)
break;
}
if(!flag)
break;
}
for(int i=;i<n;i+=k){
if(i+k-<n){
sort(num2+i,num2+i+k);
}
else
sort(num2+i,num2+n);
}
printf("Merge Sort\n");
printf("%d",num2[]);
for(int i=;i<n;i++){
printf(" %d",num2[i]);
}
}
return ;
}

最新文章

  1. bootstrap深入理解之格子布局
  2. jquery.validate使用 - 自定义验证方法
  3. iOS开发UI篇—Quartz2D简单介绍
  4. POJ 1451 T9
  5. BZOJ3563 : DZY Loves Chinese
  6. php面向对象的特性:OOP的继承
  7. CSS 概览(CSS2.1)更新时间2014-0406
  8. 如何在获取Datarow对象在其所属DataTable中的Index
  9. Unix/Linux环境C编程入门教程(29) 内存操作那些事儿
  10. ArrayList 遍历
  11. 快学 Scala 入门 3 部曲
  12. jstl 处理Date 时间
  13. v-for 在 VSCode 中出现 Elements in iteration expect to have &#39;v-bind:key&#39; directives.
  14. Django-组件拾遗
  15. Spring Boot + Spring Cloud 实现权限管理系统 后端篇(一):Kitty 系统介绍
  16. ionic开发中遇到的问题
  17. django 获取 POST 请求值的几种方法(转)
  18. A class for dynamic icons in Windows
  19. 如何写摘要(abstract)
  20. git学习------>如何用git log命令来查看某个指定文件的提交历史记录

热门文章

  1. Django商城项目笔记No.1项目准备工作
  2. leetcode 1. Two Sum [java]
  3. 详解--从地址栏输入url到页面展现中间都发生了什么?
  4. luogu P2365 任务安排
  5. DataGuard之Apply Services(redo应用和SQL应用)
  6. Project configuration is not up-to-date with pom.xml
  7. 解决:linux 固定ip 导致ping 外网unknown host
  8. python:&#39;ascii&#39; codec can&#39;t encode character
  9. Exp9 20155218 Web安全基础实践
  10. 20155320《网络对抗》Exp2 后门原理与实践