编程序实现功能:在一个元素值按升序存放的整型数组中插入一个数,使得插入后的数组元素仍然有序

#include<stdio.h>
#define N 5
void main()
{ int a[N+1],x,i,k;
for(i=0;i<N;i++)
scanf("%d",&a[i]);
scanf("%d",&x);
for(i=0;a[i]<x&&i<N;i++)
;
for(k=N;k>i;k--)
a[k]=a[k-1];
a[i]=x;
for(i=0;i<=N;i++)
printf("%5d",a[i]);
putchar('\n');
}谁能给我讲解下这个程序是怎么运行的,越详细越好 谢谢

第1个回答  2011-11-10
eeee...
#include<stdio.h>
#define N 5
void main()
{ int a[N+1],x,i,k;
// 等待输入数组
for(i=0;i<N;i++)
scanf("%d",&a[i]);
//等待输入插入数值
scanf("%d",&x);
//找到数值要插入的坐标位置 (从0开始,下标递增查找,满足数组的值<插入的数值,继续查找,找到第一个比插入数值大的数)
for(i=0;a[i]<x&&i<N;i++)
;
//从第K各开始到第N个数值,倒序赋值,其实就是向后移动一位.
for(k=N;k>i;k--)
a[k]=a[k-1];
//把插入数值放入之前找到的下标位置
a[i]=x;
//打印结果
for(i=0;i<=N;i++)
printf("%5d",a[i]);
putchar('\n');
}追问

for(i=0;a[i]<x&&i<N;i++)
;
这个后面就只有一个冒号 是怎么执行的啊

追答

这句话,其实相当于
for(i=0; i<N; i++)
{
if(a[i] < x)
continue;
}

一种缩写 你看看for语句的第二个项的含义就知道了

本回答被提问者采纳