解题思路:
首先是得输入9个数据到a[10]数组里面,可以用for循环依次输入。然后输入插入的数字t,将m与数组元素比较。
还得有一个用来确定插入数组位置的j,初始值为0。
首先确定插入数字的位置:用if语句来判断t是否大于a[i],满足条件时就将j++,不满足时就直接跳出循环可以节省时间。
然后就得将插入位置以及后面的元素往后移:从a[9]开始向前面移动,因为里面没有数据,其次也方便往后移动数据。
最后就是将数据插入指定的位置并遍历输出。
注意事项:
1.最后再插入指定位置,不然会导致数据错误。
2、移位从后往前,不然从前往后会使数据丢失或者说会将逻辑变得很复杂。
参考代码:
#include
int main()
{
int a[10],i,t,j=0,m;
for(i=0;i<9;i++){
scanf("%d",&a[i]);
}
scanf("%d",&t);
for(i=0;i<10;i++){
if(t>a[i]){
j++;
}
else
break;
}
for(i=9;i>0;i--){
if(i>j){
a[i]=a[i-1];
}
}
a[j]=t;
for(i=0;i<10;i++){
printf("%d\n",a[i]);
}
return 0;
}
0.0分
1 人评分
C语言程序设计教程(第三版)课后习题5.4 (C语言代码)浏览:1282 |
2003年秋浙江省计算机等级考试二级C 编程题(2) (C语言代码)浏览:746 |
IP判断 (C语言描述,蓝桥杯)浏览:1094 |
C语言程序设计教程(第三版)课后习题6.3 (C语言代码)from DQM浏览:652 |
蚂蚁感冒 (C语言代码)浏览:1319 |
C语言程序设计教程(第三版)课后习题9.8 (C语言代码)浏览:608 |
C语言程序设计教程(第三版)课后习题11.1 (C语言代码)浏览:486 |
2005年春浙江省计算机等级考试二级C 编程题(2) (C语言代码)浏览:567 |
IP判断 (C语言代码)浏览:533 |
检查金币 (C语言代码)浏览:1412 |