数列有序!
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 59240 Accepted Submission(s): 25564
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,请将该数插入到序列中,则有三种情况:
n个数的编号为1->n时
1.x>a[n]
将前n个数直接输出,x最后输出即可(注意格式:空格和换行符)
2.x<a[1]
先输出m,然后输出那n个数
3.a[1]<x<a[n]
i=1 to n,将a[i]与x依次进行比较,a[i]>x并且a[i]是大于x的第一个数,输出m,否则输出a[i]
仔细观察,第二种情况可以用第三种情况的代码实现
所以敲代码时 只需写出 x>a[n]和a[1]<x<a[n]的情况即可
#include<stdio.h>
int main()
{
int i,n,m;
int a[110];
while(scanf("%d%d",&n,&m),n|m)
{
int sign=0;
for(i=1;i<=n;i++)
scanf("%d",&a[i]);
if(m>a[n])
{
for(i=1;i<=n;i++)
printf("%d ",a[i]);
printf("%d\n",m);
}
// else if(m<a[1])这种情况下面的代码可以实现
// { 所以这里可以省略不写
// printf("%d",m);
// for(i=1;i<=n;i++)
// printf(" %d",a[i]);
// printf("\n");
// }
else{
for(i=1;i<=n;i++)
{
if(a[i]>m&&sign==0)
{
printf("%d ",m);
sign=1;
}
printf("%d",a[i]);
if(i!=n)
printf(" ");
else printf("\n");
}
}
}
return 0;
}