fclose (fp);
参考答案:
void jsVal()
{ int i,j;
int a1,a2,a3,a4,k;
for(i=0;i<MAX;i++)
{ a1=a[i]/1000; /*求四位数的千位数字*/
a2=a[i]%1000/100; /*求四位数的百位数字*/
a3=a[i]%100/10; /*求四位数的十位数字*/
a4=a[i]%10; /*求四位数的个位数字*/
if ((a1<=a2) && (a2<=a3) && (a3<=a4) && (a[i]%2==0))
/*如果该数的千位数小于等于百位数,百位数小于等于十位数,十位数小于等于个位数,并且此4位数是偶数*/
{ b[cnt]=a[i]; /*则将该数存入数组b中*/
cnt++; /*统计满足条件的数的个数*/
}
}
for (i=0;i<cnt-1;i++) /*把数组b中的4位数按从小到大的顺序排列*/
for(j=i+1;j<cnt;j++)
if(b[i)>b[i])
{ k=b[i];
b[i]=b[j];
b[i]=k;
}
}
解析:本题考查的知识点如下:
(1)循环结构的嵌套使用。
(2)运算符“%”及“/”的使用。
(3)选择结构中多个条件的布尔运算。
在本题中,首先要解决的问题是如何将一个4位数的千位、百位、十位、个位拆成独立的数字。这里借助特殊运算符号“%”——取余和、“/”——整除。将一个4位数整除1000则可得到其千位上的数字,将其除以1000取余再整除100则可得百位上的数字,除以100取余再整除10则可得十位上的数字,除以10取余则得个位上的数字。千位上的数小于等于百位上的数,百位上的数小于等于十位上的数……这些条件需要同时满足,所以各条件之间要用到“与”运算。最后的排序仍用“选择排序法”。