55.插入排序与归并排序
2016-03-08 22:36
78 查看
插入排序
代码:
#include
using namespace std;
int main()
{
int a[101];
int n;
cin>>n;
for(int i=1;i<=n;++i)
cin>>a[i];
for(int i=2;i<=n;++i)
{
int x=a[i];
int j=i-1;
while(x=1)
{
a[j+1]=a[j];
j--;
}
a[j+1]=x;
}
for(int i=1;i<=n;++i)
cout<<a[i]<<" ";
return 0;
}
归并排序
代码:
#include
using namespace std;
#include
void gb(int,int);
int a[101],r[101];
int main()
{
int n;
cin>>n;
for(int i=1;i<=n;++i)
cin>>a[i];
gb(1,n);
for(int i=1;i<=n;++i)
cout<<a[i]<<" ";
return 0;
}
void gb(int s,int t)
{
if(s==t) return;
int m=(s+t)/2;
gb(s,m);gb(m+1,t);
int i=s,k=s,j=m+1;
while(i<=m&&j<=t)
{
if(a[i]
{
r[k]=a[i];
i++;
k++;
}
else {
r[k]=a[j];
j++;
k++;
}
}
while(i<=m)
{
r[k]=a[i];
i++;k++;
}
while(j<=t)
{
r[k]=a[j];
j++;k++;
}
for(int i=s;i<=t;++i)
a[i]=r[i];
}
代码:
#include
using namespace std;
int main()
{
int a[101];
int n;
cin>>n;
for(int i=1;i<=n;++i)
cin>>a[i];
for(int i=2;i<=n;++i)
{
int x=a[i];
int j=i-1;
while(x=1)
{
a[j+1]=a[j];
j--;
}
a[j+1]=x;
}
for(int i=1;i<=n;++i)
cout<<a[i]<<" ";
return 0;
}
归并排序
代码:
#include
using namespace std;
#include
void gb(int,int);
int a[101],r[101];
int main()
{
int n;
cin>>n;
for(int i=1;i<=n;++i)
cin>>a[i];
gb(1,n);
for(int i=1;i<=n;++i)
cout<<a[i]<<" ";
return 0;
}
void gb(int s,int t)
{
if(s==t) return;
int m=(s+t)/2;
gb(s,m);gb(m+1,t);
int i=s,k=s,j=m+1;
while(i<=m&&j<=t)
{
if(a[i]
{
r[k]=a[i];
i++;
k++;
}
else {
r[k]=a[j];
j++;
k++;
}
}
while(i<=m)
{
r[k]=a[i];
i++;k++;
}
while(j<=t)
{
r[k]=a[j];
j++;k++;
}
for(int i=s;i<=t;++i)
a[i]=r[i];
}
相关文章推荐
- 55.插入排序与归并排序
- Genymotion 和 virtualbox 安装时候出的问题
- 接口
- DLL的概念、分类、调用,DLL如何导出函数、变量和类
- ViewController的生命周期
- 3.memcached的基本命令
- 值得推荐的android开源框架
- [matlab]代码优化
- 矩阵的交
- 去掉UItableview headerview黏性(sticky)
- Android网络编程概述
- BZOJ 1025: [SCOI2009]游戏 背包DP
- Homework 1 -- The beginning
- ***LeetCode 95. Unique Binary Search Trees II
- 2016-03-08
- 1040. Longest Symmetric String (25) 最长回文子串
- 【Bug】Spark sql jdbc fails for Oracle NUMBER type columns
- 学习记录-Qt读取条码扫描枪
- Git 版本管理
- 开博小记