编程序实现功能:在一个元素值按升序存放的整型数组中插入一个数,使得插入后的数组元素仍然有序
#include<stdio.h>#defineN5voidmain(){inta[N+1],x,i,k;for(i=0;i<N;i++)scanf("%d",&a[i]...
#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');
}谁能给我讲解下这个程序是怎么运行的,越详细越好 谢谢 展开
#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个回答
展开全部
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');
}
#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语句的第二个项的含义就知道了
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询