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