数列有序!
2015-10-06 16:40
246 查看
Problem Description
有n(n<=100)个整数,已经按照从小到大顺序排列好,现在另外给一个整数x,请将该数插入到序列中,并使新的序列仍然有序。
Input
输入数据包含多个测试实例,每组数据由两行组成,第一行是n和m,第二行是已经有序的n个数的数列。n和m同时为0标示输入数据的结束,本行不做处理。
Output
对于每个测试实例,输出插入新的元素后的数列。
Sample Input
3 3
1 2 4
0 0
Sample Output
1 2 3 4
有n(n<=100)个整数,已经按照从小到大顺序排列好,现在另外给一个整数x,请将该数插入到序列中,并使新的序列仍然有序。
Input
输入数据包含多个测试实例,每组数据由两行组成,第一行是n和m,第二行是已经有序的n个数的数列。n和m同时为0标示输入数据的结束,本行不做处理。
Output
对于每个测试实例,输出插入新的元素后的数列。
Sample Input
3 3
1 2 4
0 0
Sample Output
1 2 3 4
#include<stdio.h> #include<string.h> int a[3000]; int main() { int n,m; while(scanf("%d%d",&n,&m),n||m) { memset(a,0,sizeof(a)); for(int i=0;i<n;i++) scanf("%d",&a[i]); if(m<a[0]) { printf("%d ",m); for(int i=0;i<n-1;i++) printf("%d ",a[i]); printf("%d\n",a[n-1]); } else if(m>a[n-1]) { for(int i=0;i<n;i++) printf("%d ",a[i]); printf("%d\n",m); } else { int k; for(int i=0;i<n-1;i++) { <span style="color:#33cc00;"> // if(m>a[i]&&m<a[i+1])如果写成这样的话当输入3 3 1 3 4时,会陷入死循环!!</span> <span style="color:#ff0000;">if((m>a[i]&&m<a[i+1])||m==a[i]||m==a[i+1]) </span> { k=i; break; } } for(int i=0;i<=k;i++) printf("%d ",a[i]); printf("%d ",m); for(int j=k+1;j<n-1;j++) printf("%d ",a[j]); printf("%d\n",a[n-1]); } } return 0; }
相关文章推荐
- 【Linux 移植 】——5、移植 u-boot-2012.04.01 之 支持Nor Flash
- iOS开发小项目之找色块游戏
- 相同概率的抽奖程序另类实现——使用数据库,无需数学原理
- 九度OJ 1533 最长上升子序列 (基于贪心和二分查找)
- git与github的使用
- mac 卸载mysql数据库
- Java基础知识强化之集合框架笔记40:Set集合之HashSet存储自定义对象并遍历
- 光棍
- 【笔试】54、不用加减乘除做加法
- 深入 HBase 架构解析(2)
- 连接数据库步骤
- leetcode:Search for a Range(数组,二分查找)
- 最高分是多少(线段树) 华为2016校园招聘
- IO流
- 深入 HBase 架构解析(1)
- HDU 1058
- 6.Swift 触摸实现缩放
- C#学习日记15----引用类型 之 string类型用法总结
- python 网络编程(一):socket 模块
- leetcode题目 寻找和为SUM的集合系列问题