就业数据资源平台
当前位置:首页 > 网络技术
2012年计算机三级网络技术考试上机练习题12

题目38(整数各位打散组合运算题)

已知数据文件IN.DAT中存有200个四位数,并已调用读函数readDat()把这些数存入数组a中,请考生编制一函数jsVal(),其功能是:把个位数字和千位数字重新组成一个新的十位数(新十位数的十位数字是原四位数的个位数字,新十位数的个位数字是原四位数的千位数字),以及把百位数字和十位数字组成另一个新的十位数(新十位数的十位数字是原四位数的百位数字,新十位数的个位数字是原四位数的十位数字),如果新组成的两个十位数必须是一个奇数,另一个为偶数并且两个十位数中至少有一个数能被17整除,同时两个新数的十位数字均不为零,则将满足此条件的四位数按从大到小的顺序存入数组b中,并要计算满足上述条件的四位数的个数cnt。最后main()函数调用写函数writeDat()把结果cnt以及数组b中符合条件的四位数输出到


OUT.DAT文件中。


    void jsVal()


{int i,j,thou,hun,ten,data,ab,cd;中华考试网(www.Examw。com)


 for(i=0;i<MAX;i++)


  {thou=a[i]/1000;   hun=a[i]/100%10;


   ten=a[i]%100/10;  data=a[i]%10;


   ab=10*data+thou;  cd=10*hun+ten;


   if((ab%2!=cd%2)&&((ab%17==0||cd%17==0)&&ab>=10&&cd>=10))


     b[cnt++]=a[i];


  }


 for(i=0;i<cnt-1;i++)


   for(j=i+1;j<cnt;j++)


     if(b[i]<b[j])  {data=b[i];b[i]=b[j];b[j]=data;}


}


题目39(整数各位打散组合运算题)


已知数据文件IN.DAT中存有200个四位数,并已调用读函数readDat()把这些数存入数组a中,请考生编制一函数jsVal(),其功能是:把千位数字和十位数字重新组成一个新的十位数ab(新十位数的十位数字是原四位数的千位数字,新十位数的个位数字是原四位数的十位数字),以及把个位数字和百位数字组成另一个新的十位数cd(新十位数的十位数字是原四位数的个位数字,新十位数的个位数字是原四位数的百位数字),如果新组成的两个十位数ab>cd,ab必须是偶数且能被5整除,cd必须是奇数,同时两个新数的十位数字均不为零,则将满足此条件的四位数按从大到小的顺序存入数组b中,并要计算满足上述条件的四位数的个数cnt。最后main()函数调用写函数writeDat( )把结果cnt以及数组b中符合条件的四位数输出到OUT.DAT文件中。


void jsVal()


{int i,j,thou,hun,ten,data,ab,cd;


 for(i=0;i<MAX;i++)


   {thou=a[i]/1000;    hun=a[i]%1000/100;


    ten=a[i]%100/10;   data=a[i]%10;


    ab=10*thou+ten;    cd=10*data+hun;


    if((ab-cd)>0&&(ab%2!=1&&ab%5==0)&&cd%2==1&&ab>=10&&cd>=10)


      {b[cnt]=a[i];cnt++;}


   }


  for(i=0;i<cnt-1;i++)


    for(j=i+1;j<cnt;j++)


       if(b[i]<b[j]) {data=b[i];b[i]=b[j];b[j]=data;}


}


题目40(素数题)


无忧id 102 题提供了求素数isPrime()函数


程序prog1.c的功能是:选出100以上1000之内所有个位数字与十位数字之和被10除所得余数恰是百位数字的素数(如293)。计算并输出上述这些素数的个数cnt以及这些素数值的和sum。 请考生编写函数countValue( )实现程序要求,最后调用函数writeDAT()把结果cnt和sum输出到文件bc10.out中。


   int isPrime(int m)


{


 int i;


 for(i=2;i<m;i++)


   if(m % i==0)return 0;


 return 1;转自:考试网 - [Examw.Com]


}


void countValue()


{ int i,j,bw,sw,gw;


  for(i=100;i<1000;i++)


   { bw=i/100;  sw=i%100/10; gw=i%10;


           if(isPrime(i)&&(gw+sw)%10==bw)  { cnt++; sum+=i;}


   }


}


题目41(素数统计排序题)


已知数据文件in.dat中存有300个四位数,并已调用读函数ReadDat()把这些数存入数组a中,请编制一函数jsValue(),其功能是:求出所有这些四位数是素数的个数cnt,再把所有满足此条件的四位数依次存入数组b中,然后对数组b的四位数按从小到大的顺序进行排序,最后调用写函数writeDat()把结果输出到out.dat文件。


    例如:5591是素数,则该数满足条件存入数组b中,且个数cnt=cnt+1。9812是非素数,则该数不满足条件忽略。


int isP(int m){


  int i;


  for(i=2;i<m;i++)


    if(m%i==0)return 0;


    return 1;


}


jsValue()中 华 考 试 网


{int i,j,value;


 for(i=0;i<300;i++)


   if(isP(a[i])) b[cnt++]=a[i];


 for(i=0;i<cnt-1;i++)


   for(j=i+1;j<cnt;j++)


     if(b[i]>b[j])  {value=b[i]; b[i]=b[j]; b[j]=value;}


}


★☆题目42(素数题)


下列程序的功能是:找出所有100以内(含100)满足I,I+4,I+10都是素数的整数I(I+10也在100以内)的个数cnt以及这些I之和sum。请编写函数countValue()实现程序要求的功能,最后调用函数writeDat()把结果cnt和sum输出到文件out.dat中。


int isPrime(int m)


{


 int i;


 for(i=2; i<m; i++)


  if(m % i ==0) return 0 ;


 return 1;


}


void countValue()


{int i;


 for(i=2;i<=90;i++)


   if(isPrime(i)&&isPrime(i+4)&&isPrime(i+10))


     {cnt++;sum+=i;}


}


运行结果为:


满足条件的整数的个数=7


满足条件的整数的和值=201

就业数据资源平台