下次类推,即用第二个元素与后8个进行比较,并进行交换。
2.程序源代码: #define n 10 main()
{int i,j,min,tem,a[n];
/*input data*/
printf(\
for(i=0;i{ printf(\ scanf(\ printf(\
for(i=0;iprintf(\
printf(\ /*sort ten num*/ for(i=0;i{min=i;
for(j=i+1;jif(a[min]>a[j]) min=j;
tem=a[i]; a[i]=a[min]; a[min]=tem;
}
/*output data*/ printf(\ for(i=0;iprintf(\
}
==============================================================
【程序38】
题目:求一个3*3矩阵对角线元素之和
1.程序分析:利用双重for循环控制输入二维数组,再将a[i][i]累加后输出。
2.程序源代码:
main() {
float a[3][3],sum=0;
int i,j;
printf(\
for(i=0;i<3;i++) for(j=0;j<3;j++) scanf(\
for(i=0;i<3;i++) sum=sum+a[i][i];
printf(\
}
==============================================================
【程序39】
题目:有一个已经排好序的数组。现输入一个数,要求按原来的规律将它插入数组
中。
1. 程序分析:首先判断此数是否大于最后一个数,然后再考虑插入中间的数的情况,
插入后
此元素之后的数,依次后移一个位置。
2.程序源代码:
main() {
int a[11]={1,4,6,9,13,16,19,28,40,100};
int temp1,temp2,number,end,i,j; printf(\
for(i=0;i<10;i++) printf(\
printf(\
printf(\
scanf(\
end=a[9]; if(number>end) a[10]=number;
else
{for(i=0;i<10;i++) { if(a[i]>number) {temp1=a[i]; a[i]=number; for(j=i+1;j<11;j++)
{temp2=a[j]; a[j]=temp1; temp1=temp2;
}
break; } } }
for(i=0;i<11;i++) printf(\
}
==============================================================
【程序40】
题目:将一个数组逆序输出。 1.程序分析:用第一个与最后一个交换。
2.程序源代码: #define n 5 main()
{ int a[n]={9,6,5,4,1},i,temp; printf(\ for(i=0;i printf(\
for(i=0;i {temp=a[i]; a[i]=a[n-i-1]; a[n-i-1]=temp;
}
printf(\ for(i=0;i printf(\
}