#define MAX 200
int a[MAX], b[10].
void jsVal()
{
}
void readDat()
{
int i .
FILE *fp .
fp = fopen(in.dat, r) .
for(i = 0 . i < MAX . i ) fscanf(fp, %d, &.a[i]) .
fclose(fp) .
}
void main()
{
int i .
readDat() .
jsVal() .
for(i = 0 . i < 10 . i )
printf(b[%d]=%d\n, i, b[i]) .
writeDat() .
}
writeDat()
{
FILE *fp .
int i .
fp = fopen(out.dat, w) .
for(i = 0 . i < 10 . i ) fprintf(fp, %d\n, b[i]) .
fclose(fp) .
}
参考答案:
#include
#define MAX 200
int a[MAX], b[10].
void jsVal()
{
int i,j,k. /* j,k,i-循环变量 */
int iMax.
for(i=0.i<10.i ) /* 根据取数要求循环 */
{
iMax=0.
for(j=i*20.j<(i 1)*20.j ) if(iMaxb[i]=iMax.
for(j=0.j{
if(b[j]>iMax) /* 在b中寻找dt的位置 */
{
for(k=i.k>j.k--) b[k]=b[k-1]. /* 顺序移动 */
b[j]=iMax.
break.
}
}
}
}
void readDat()
{
int i .
FILE *fp .
fp = fopen(in.dat, r) .
for(i = 0 . i < MAX . i ) fscanf(fp, %d, &.a[i]) .
fclose(fp) .
}
void main()
{
int i .
readDat() .
jsVal() .
for(i = 0 . i < 10 . i )
printf(b[%d]=%d\n, i, b[i]) .
writeDat() .
}
writeDat()
{
FILE *fp .
int i .
fp = fopen(out.dat, w) .
for(i = 0 . i < 10 . i ) fprintf(fp, %d\n, b[i]) .
fclose(fp) .
}
本题评析:
本题,是一道考察循环和数组排序的题目,通过20个一个平均一般可以安排两层循环,结合本题获得10个最大值的要求,在外层安排0-9的循环。
数组的排序一般可以使用冒泡和二分等算法排序,在本题目中,加入的因素是可以在获得数据后直接在数组中寻找到合适的位置,这样我们可以假设b已经是有序的数组,可以简化程序。