全国计算机二级机试题库完全版.docx
《全国计算机二级机试题库完全版.docx》由会员分享,可在线阅读,更多相关《全国计算机二级机试题库完全版.docx(45页珍藏版)》请在冰豆网上搜索。
全国计算机二级机试题库完全版
一、素数题:
题目1.请编写一个函数jsValue(intm,intk,intxx[]),该函数的功能是:
将大于整数m且紧靠m的k个素数存入数组xx传回。
例如:
若输入175则应输出:
19,23,29,31,37。
intisP(intm)
{
inti;
for(i=2;iif(m%i==0)return0;
return1;
}
voidnum(intm,intk,intxx[])
{ints=0;
for(m=m+1;k>0;m++)
if(isP(m)){xx[s++]=m;k--;}
}
题目34.程序prog1.c的功能是:
选出100以上1000之内所有个位数字与十位数字之和被10除所得余数恰是百位数字的素数(如293)。
计算并输出上述这些素数的个数cnt以及这些素数值的和sum。
请考生编写函数countValue()实现程序要求
voidcountValue()
{inti,j,bw,sw,gw;
for(i=100;i<1000;i++)
{bw=i/100;sw=i%100/10;gw=i%10;
for(j=2;j
if(i%j==0)break;
if((i==j)&&(gw+sw)%10==bw){cnt++;sum+=i;}
}
}
55、已知数据文件in.dat中存有300个四位数,并已调用读函数ReadDat()把这些数存入数组a中,请编制一函数jsValue(),其功能是:
求出所有这些四位数是素数的个数cnt,再把所有满足此条件的四位数依次存入数组b中,然后对数组b的四位数按从小到大的顺序进行排序,最后调用写函数writeDat()把结果输出到out.dat文件。
例如:
5591是素数,则该数满足条件存入数组b中,且个数cnt=cnt+1。
9812是非素数,则该数不满足条件忽略。
#include
inta[300],b[300],cnt=0;
intisP(intm){
inti;
for(i=2;iif(m%i==0)return0;
return1;
}
jsValue()
{inti,j,value;
for(i=0;i<300;i++)
if(isP(a[i]))b[cnt++]=a[i];
for(i=0;ifor(j=i+1;jif(b[i]>b[j]){value=b[i];b[i]=b[j];b[j]=value;}
}
题目64下列程序的功能是:
找出所有100以内(含100)满足I,I+4,I+10都是素数的整数I(I+10也在100以内)的个数cnt以及这些I之和sum。
请编写函数countValue()实现程序要求的功能
intisPrime(intnumber)
{inti,tag=1;
for(i=2;tag&&i<=number/2;i++)
if(number%i==0)tag=0;
returntag;
}
voidcountValue()
{inti;
for(i=2;i<=90;i++)
if(isPrime(i)&&isPrime(i+4)&&isPrime(i+10))
{cnt++;sum+=i;}
}
题目66、下列程序prog1.c的功能是:
计算500-800区间内素数的个数cnt,并按所求素数的值从大到小的顺序,再计算其间隔加、减之和,即第1个素数-第2个素数+第3个素数-第4个素数+第5个素数...的值sum。
请编写函数countValue()实现程序的要求
voidcountValue()
{inti,j,k=1;
for(i=800;i>500;i--)
{for(j=2;j
if(i%j==0)break;
if(j==i){cnt++;sum=sum+k*i;k=k*(-1);}
}
}
题目82.已知数据文件in.dat中存有300个四位数,请编制一函数jsValue(),其功能是:
求出所有这些四位数是素数的个数cnt,再求出所有满足此条件的四位数平均值pjz1,以及不满足此条件的四位数平均值pjz2。
例如:
5591是素数,则该数满足条件计算平均值pjz1,且个数cnt=cnt+1。
9812是非素数,则该数不满足条件计算平均值pjz2。
程序中已定义数组:
a[300],已定义变量:
cnt,pjz1,pjz2。
#include
inta[300],cnt=0;
doublepjz1=0.0,pjz2=0.0;
intisP(intm)
{inti;
for(i=2;iif(m%i==0)return0;
return1;
}
jsValue()
{inti;
for(i=0;i<300;i++)
if(isP(a[i])){pjz1+=a[i];cnt++;}
elsepjz2+=a[i];
if(cnt==0)pjz1=0;
elsepjz1/=cnt;
if(300-cnt==0)pjz2=0;
elsepjz2/=(300-cnt);
}
二、结构体
题目7已知在文件IN.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位),产品名称mc(字符型10位),单价dj(整型),数量sl(整型),金额je(长整型)五部分组成。
其中:
金额=单价*数量计算得出。
请编制函数SortDat(),其功能要求:
按产品代码从大到小进行排列,若产品代码相同,则按金额从大到小进行排列,最终排列结果仍存入结构数组sell中
voidSortDat()
{inti,j;
PROxy;
for(i=0;i<99;i++)
for(j=i+1;j<100;j++)
if(strcmp(sell[i].dm,sell[j].dm)<0||strcmp(sell[i].dm,sell[j].dm)==0&&sell[i].je{xy=sell[i];
sell[i]=sell[j];sell[j]=xy;} }
题目13每个产品销售记录由产品代码dm(字符型4位),产品名称mc(字符型10位),单价dj(整型),数量sl(整型),金额je(长整型)五部分组成。
其中:
金额=单价*数量计算得出。
编制函数SortDat(),其功能要求:
按产品代码从小到大进行排列,若产品代码相等,则按金额从大到小进行排列,最终排列结果仍存入结构数组sell中:
voidSortDat()
{inti,j;
PROxy;
for(i=0;i<99;i++)
for(j=i+1;j<100;j++)
if(strcmp(sell[i].dm,sell[j].dm)>0||strcmp(sell[i].dm,sell[j].dm)==0&&sell[i].je{xy=sell[i];sell[i]=sell[j];sell[j]=xy;}
}
题目38编制函数SortDat(),其功能要求:
按产品代码从小到大进行排列,若产品代码相同,则按金额从小到大进行排列,最终排列结果仍存入结构数组sell中
voidSortDat()
{inti,j;
PROxy;
for(i=0;i<99;i++)
for(j=i+1;j<100;j++)
if(strcmp(sell[i].dm,sell[j].dm)>0||strcmp(sell[i].dm,sell[j].dm)==0&&sell[i].je>sell[j].je)
{xy=sell[i];sell[i]=sell[j];sell[j]=xy;}
}
题目12编制函数SortDat(),其功能要求:
按产品名称从小到大进行排列,若产品名称相等,则按金额从小到大进行排列,最终排列结果仍存入结构数组sell中
voidSortDat()
{inti,j;
PROxy;
for(i=0;i<99;i++)
for(j=i+1;j<100;j++)
if(strcmp(sell[i].mc,sell[j].mc)>0||strcmp(sell[i].mc,sell[j].mc)==0&&sell[i].je>sell[j].je)
{xy=sell[i];sell[i]=sell[j];sell[j]=xy;}
}
题目32SortDat(),其功能要求:
按产品名称从大到小进行排列,若产品名称相等,则按金额从小到大进行排列,最终排列结果仍存入结构数组sell中
voidSortDat()
{inti,j;
PROxy;
for(i=0;i<99;i++)
for(j=i+1;j<100;j++)if(strcmp(sell[i].mc,sell[j].mc)<0||strcmp(sell[i].mc,sell[j].mc)==0&&sell[i].je>sell[j].je)
{xy=sell[i];sell[i]=sell[j];sell[j]=xy;}
}
题目42SortDat(),其功能要求:
按产品名称从大到小进行排列,若产品名称相等,则按金额从大到小进行排列,最终排列结果仍存入结构数组sell中
voidSortDat()
{inti,j;
PROxy;
for(i=0;i<99;i++)
for(j=i+1;j<100;j++)
if(strcmp(sell[i].mc,sell[j].mc)<0||strcmp(sell[i].mc,sell[j].mc)==0&&sell[i].je{xy=sell[i];sell[i]=sell[j];sell[j]=xy;}
}
题目31函数SortDat(),其功能要求:
按金额从大到小进行排列,若金额相同,则按产品代码从大到小进行排列,最终排列结果仍存入结构数组sell中
voidSortDat()
{inti,j;
PROxy;
for(i=0;i<99;i++)
for(j=i+1;j<100;j++)if(sell[i].je{xy=sell[i];sell[i]=sell[j];sell[j]=xy;}
}
题目47函数SortDat(),其功能要求:
按金额从大到小进行排列,若金额相等,则按产品代码从小到大进行排列,最终排列结果仍存入结构数组sell中,最后调用函数WriteDat()把结果输出到文件OUT3.DAT中。
voidSortDat()
{inti,j;
PROxy;
for(i=0;i<99;i++)
for(j=i+1;j<100;j++)
if(sell[i].je0)
{xy=sell[i];sell[i]=sell[j];sell[j]=xy;}
}
题目61函数SortDat