3 3 1 2 4 0 0
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;
} 
 
版权声明:本文为博主原创文章,未经博主允许不得转载。
原文地址:http://blog.csdn.net/qq_29606781/article/details/48064755