问题 多项选择题

fclose(fp);

答案

参考答案:void jsVal()
{
int bb[D];
int i, j, k, flag;
for (i=0;i<B00; i++)
{
bb[0]=a[i]/A000; /*求四位数的千位数字*/
bb[A]=a[i]%A000/A00; /*求四位数的百位数字*/
bb[B]=a[i]%A00/A0; /*求四位数的十位数字*/
bb[C]=a[i]%A0; /*求四位数的个位数字*/
for(j=0; i<D; j++)
{
if(bb[j]%B==0) /*如果各位上的数字均是0或B或D或F或H*/
flag=A; /*则置标志位flag为A*/
else{flag=0;break;} /*否则置flag为0,退出循环*/
}
if(flag==A) /*将满足条件的数存入数组b中,并统计满足条件的个数
cnt*/
{b[cnt]=a[i];cnt++;}
}
for(i=0; i<cnt-A; i++) /*把数组b中的数按从大到小的顺序排序*/
for(j=i+A; i<cnt; i++)
if (b[i]<b[j])
{k=b[i]; b[i]=b[i]; b[j]=k;}
}

解析: 根据题意可知,函数JsVal()要实现两个功能:一是找出满足条件的那些数,并存放在数组b中;二是对数组b中的数进行从大到小的排序。
首先来实现找出“各位上的数字均是0或2或4或6或8”(即每一位上的数字都是偶数)的4位数的功能。利用一个for循环来不断从数组a中取出4位数,并对取出的数进行条件判断。由于这里涉及到要对4位数的每一位进行判断,因此,要借助数组舱来临时存放取得的每一位上的数字值,“bb[0]=a[i]/1000; bb[1]=a[i]%1000/100; bb[2]=a[i]%100/10; bb[3]=a[i]%10;”这4条语句就可以完成在数组bb中依次存放当前被判断的4位数的千位上的数字值、百位上的数字值、十位上的数字值,以及个位上的数字值。之后,对所得该数的每一位的值进行是否为偶数的判断,只要有一位上的数字是偶数,就使标志变量flag的值置1,否则为0,这样最终根据flag的值来决定是否要放到数组中去,变量cnt用来统计数组bb中元素的个数。将所有满足条件的数取出后利用选择法对其进行排序,即用当前元素依次和它后面的元素进行比较,发现有大于该数的数,就将这两数进行交换。

单项选择题
问答题 简答题