printf("%d ",a[i]);
}
printf("\ninput number:\n");
scanf("%d",&n);
for(i=0;i<10;i++)
if(n>a[i])
谭浩强 C 语言程序设计 2001 年 5 月 1 日
{for(s=9;s>=i;s--) a[s+1]=a[s];
break;}
a[i]=n;
for(i=0;i<=10;i++)
printf("%d ",a[i]);
printf("\n");
}
本程序首先对数组 a 中的 10 个数从大到小排序并输出排序结果。然后输入要chā入的整
数 n。再用一个 for 语句把 n 和数组元素逐个比较,如果发现有 n>a[i]时,则由一个内循环
把 i 以下各元素值顺次后移一个单元。后移应从后向前进行(从 a[9]开始到 a[i]为止)。 后
移结束跳出外循环。chā入点为 i,把 n 赋予 a[i]即可。 如所有的元素均大于被chā入数,则
并未进行过后移工作。此时 i=10,结果是把 n 赋于 a[10]。最后一个循环输出chā入数后的数
组各元素值。
程序运行时,输入数 47。从结果中可以看出 47 已chā入到 54 和 28 之间。
【例 7.19】在二维数组 a 中选出各行最大的元素组成一个一维数组 b。
a=( 3 16 87 65
4 32 11 108
10 25 12 37)
b=(87 108 37)
本题的编程思路是,在数组 A 的每一行中寻找最大的元素,找到之后把该值赋予数组 B
相应的元素即可。程序如下:
main()
{
int a[][4]={3,16,87,65,4,32,11,108,10,25,12,27};
int b[3],i,j,l;
for(i=0;i<=2;i++)
{ l=a[i][0];
for(j=1;j<=3;j++)
if(a[i][j]>l) l=a[i][j];
b[i]=l;}
printf("\narray a:\n");
for(i=0;i<=2;i++)
{ for(j=0;j<=3;j++)
printf("%5d",a[i][j]);
printf("\n");}
printf("\narray b:\n");
for(i=0;i<=2;i++)
printf("%5d",b[i]);
printf("\n");
}
谭浩强 C 语言程序设计 2001 年 5 月 1 日
程序中第一个 for 语句中又嵌套了一个 for 语句组成了双重循环。外循环控制逐行处理,
并把每行的第 0 列元素赋予 l。进入内循环后,把 l