几种解题思路对比:
第一种:
for (i = 0; i < 9; i++)
scanf("%d", &a[i]);
scanf("%d", &n);
for (i = 0; i < 9; i++)
{
if (n <= a[i])
{
for (j = 9; j > i; j--)
a[j] = a[j - 1];
break;
}
}
a[i] = n;
for (i = 0; i < 10; i++)
printf("%d\n", a[i]);
第二种:
i=0;
while(x>a[i])
{
i++; //找到位置
}
int j;
for(j=0;j<i;j++)
{
printf("%d\n",a[j]); //输出那个位置之前的数
}
printf("%d\n",x); //输出插入的数
for(i;i<9;i++)
{
printf("%d\n",a[i]); //输出那个位置之后的数
}
第三种:(思路和第二种相似)
int a[9], b, i;
for ( i = 0; i < 9; i++) {
scanf("%d", &a[i]);
}
scanf("%d", &b);
for ( i = 0; i < 9; i++) {
if (b < a[i]) { printf("%d\n", b); break; } //插入输出,然后退出for循环
else printf("%d\n", a[i]);
}
for (; i < 9; i++) { //接着输出后续的
printf("%d\n", a[i]);
}
第四种:
#include<stdio.h>
int main()
{
int a[9];
int b;
int c[10];
int i,j;
int m;
for(i=0;i<9;i++) //通过遍历,输入9个数组元素
{
scanf("%d",&a[i]);
}
scanf("%d",&b);//插入一个数;
for(i=0;i<10;i++) //将a[9]数组中的9个元素和新插入数b的值,一并赋到新的c[10]的数组中元素中;
{
if(i<9)
{
c[i]=a[i];
}
else
{
c[i]=b;
}
}
for(j=0;j<10;j++) //通过冒泡程序,设置冒泡次数,将新的c[10]数组中的元素,按照从小到大的顺序排列;
{
for(i=0;i<10-1;i++) //第一次冒泡,在冒泡过程中10-1,是指下标,i到8即可,否则在以下加次运算中,i+1会出现a[10]这个数组元素值,而这个元素值是垃圾值。
{
if(c[i]>c[i+1])
{
m=c[i];
c[i]=c[i+1];
c[i+1]=m;
}
}
}
for(i=0;i<10;i++) //输出
{
printf("%d\n",c[i]);
}
return 0;
}
0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复