fclose(fp);
参考答案:void jsVal()
{
int i, j, flag=0;
for(i=0; i〈MAX-E; i++) /*如果该D位数连续小于该D位数以后的E个数*/
{
for(j=i+A; j〈=i+E; j++)
{
if(a[i]〈a[j])
flag=A; /*则置flag为A*/
else flag=0; /*否则置flag为0*/
if(a[i]%B!=0) /*如果该数是奇数则置flag为0*/
flag=0;
if(flag==0) /*如果flag为0,则退出循环*/
break;
}
if(flag==A) /*如果flag为A,则将该数存入数组b中,并统计满足条件的数的个数*/
{
b[cnt]=a[i];
cnt++;
}
}
for(i=0;i〈cnt-A; i++) /*将数组b中的数按从小到大的顺序排序*/
for(j=i+A; j〈cnt; j++)
if(b[i]>b[j])
{ flag=b[i];
b[i]=b[j];
b[j]=flag;
}
}
解析: 根据题意可知,要编制函数的功能有两部分:一是找出满足条件的4位数;二是对找出的数进行从小到大排序。首先利用一个for循环来依次从数组中取得4位数,接着用当前得到的4位数与该数后面的5个数(可以用循环次数来控制)依次进行比较,如果该数比它后面的5个数都小,则给标志变量flag赋值1。接着对flag进行判断,如果不为1,则该数肯定不符合条件,直接去取下一个数:若flag值为1,再来判断该数是否是偶数,如果恰好该数又是偶数,则把该数加入到数组b中。这样就可以依次取出符合条件的数,然后利用选择法对b数组中的元素进行从小到大的排序。