计算机等考三级数据库上机题及答案1.docx

上传人:b****5 文档编号:3433427 上传时间:2022-11-23 格式:DOCX 页数:10 大小:18.30KB
下载 相关 举报
计算机等考三级数据库上机题及答案1.docx_第1页
第1页 / 共10页
计算机等考三级数据库上机题及答案1.docx_第2页
第2页 / 共10页
计算机等考三级数据库上机题及答案1.docx_第3页
第3页 / 共10页
计算机等考三级数据库上机题及答案1.docx_第4页
第4页 / 共10页
计算机等考三级数据库上机题及答案1.docx_第5页
第5页 / 共10页
点击查看更多>>
下载资源
资源描述

计算机等考三级数据库上机题及答案1.docx

《计算机等考三级数据库上机题及答案1.docx》由会员分享,可在线阅读,更多相关《计算机等考三级数据库上机题及答案1.docx(10页珍藏版)》请在冰豆网上搜索。

计算机等考三级数据库上机题及答案1.docx

计算机等考三级数据库上机题及答案1

1.调用函数rwdata(),从IN.dat文件中读取10组数据(m和k值),并嵌套调用primenum函数分别得出array[]数组。

请编写函数primenum(intm,intk,intarray[]),该函数的功能是:

将紧靠m的k个素数存入数组array并在屏幕上显示。

最后把结果输出到文件OUT.dat中。

  例如,若输入39,则应输出5711131719232931。

  注意:

部分程序已经给出。

请勿改动主函数main()和输出数据函数rwdata()的内容。

  【答案】

  voidprimenum(intm,intk,intarray[])

  {intvalue=m+1;

  inthalf,n=0,i;

  while

(1)

  {half=value/2;

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

  if(value%i==0)

  break;

  if(i>half)

  {array[n]=value;

  n++;

  }

  if(n>=k)

  break;

  value++;

  }

  }

  2.在文件IN.dat中有200个正整数,且每个数均在1000~9999之间。

函数RData()读取这200个数存放到数组original中。

请编写函数numAscend(),其功能是:

要求按每个数的后3位的大小进行升序排列,然后取出满足此条件的前10个数依次存入数组result中,如果后3位的数值相等,则按原先的数值进行降序排列。

最后调用函数WData(),把结果result输出到文件OUT.dat中。

  例如,处理前:

60125099901270258088

  处理后:

90126012702580885099

  【答案】

  voidnumascend()

  {inti,j,data;

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

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

  {if(original[i]%1000>original[j]%1000)

  {data=original[i];

  original[i]=original[j];

  original[j]=data;

  }

  elseif(original[i]%1000==original[j]%1000)

  {if(original[i]

  {data=original[i];

  original[i]=original[j];

  original[j]=data;

  }

  }

  }

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

  result[i]=original[i];

  }

  3.已知文件IN.dat中存有100个产品销售记录,每个产品销售记录由产品代码code(字符型4位)、产品名称name(字符型10位)、单价uprice(整型)、数量amount(整型)、金额sum(长整型)5部分组成。

其中:

金额=单价×数量。

函数RData()读取这100个销售记录并存入结构数组sell中。

请编写函数DescSort(),其功能要求:

按产品代码从大到小进行排列,若产品代码相同,则按金额从大到小进行排列,最终排列结果仍存入结构数组sell中,最后调用函数WData(),把结果输出到文件OUT.dat中。

  【答案】

  voidDescSort()

  {inti,j;

  PROtemp;

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

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

  if(strcmp(sell[i].code,sell[j].code)<0)

  {temp=sell[i];

  sell[i]=sell[j];

  sell[j]=temp;

  }

  elseif(strcmp(sell[i].code,sell[j].code)==0)

  {if(sell[i].sum

  {temp=sell[i];

  sell[i]=sell[j];

  sell[j]=temp;

  }

  }

  }

 4.函数RData()实现从文件IN.dat中读取一篇英文文章,存入到字符串数组str中;请编写encryptChar()函数,其功能是:

按给定的替代关系对数组str中的所有字符进行替代,仍存入数组str对应的位置上,最后调用函数WData(),把结果str输出到文件OUT.dat中。

  替代关系:

f(p)=p*11mod256(p是数组中某一个字符的ASCII值,f(p)是计算后新字符的ASCII值),如果计算后f(p)值小于1等于32或大于130,则该字符不变,否则将f(p)所对应的字符进行替代。

  原始数据文件存放的格式是:

每行的宽度均小于80个字符。

  【答案】

  voidencryptChar()

  {inti;

  char*pf;

  for(i=0;i<>

  {pf=str[i];

  while(*pf!

=0)

  {if(*pf*11%256<=130&&*pf*11%256>32)

  *pf=*pf*11%256;

  pf++;

  }

  }

  }

  5.函数RData()实现从文件IN.dat中读取一篇英文文章存入到字符串数组str中,请编写函数DescSort(),其功能是:

以行为单位对字符按从大到小的顺序进行排序,排序后的结果仍按行重新存入字符串数组str中,最后调用函数WData(),把结果str输出到文件OUT.dat中。

原始数据文件存放的格式是:

每行的宽度均小于80个字符(含标点符号和空格)。

  例如,原文:

dAeBfC.

  CcbbAA

  结果:

fedCBA.

  cbbCAA

  【答案】

  voidDescSort(void)

  {inti,j,k,strl;

  charch;

  for(i=0;i<>

  {strl=strlen(str[i]);

  for(j=0;j<>

  for(k=j+1;k<>

  if(str[i][j]

  {ch=str[i][j];

  str[i][j]=str[i][k];

  str[i][k]=ch;

  }

  }

  }

  6函数RData()实现从文件IN.dat中读取一篇英文文章存入字符串数组original中,请编写StrCharMove()函数,其功能是:

以行为单位把字符串中所有字符的ASCII值右移4位,然后把右移后的字符ASCII值再加上原字符的ASCII值,得到新的字符仍存入原字符串对应的位置上。

最后把已处理的字符串仍按行重新存入字符串数组original中。

最后调用函数WData(),把结果original输出到文件OUT.dat中。

  原始数据文件存放的格式是:

每行的宽度均小于80个字符(含标点符号和空格)。

  【答案】

  voidStrCharMove(void)

  {inti,j,strl;

  for(i=0;i<>

  {strl=strlen(original[i]);

  for(j=0;j<>

  original[i][j]+=original[i][j]>>4;

  }

  }

7.编写函数findStr(),其功能是:

统计一个长度为2的子字符串在另一个字符串中出现的次数。

例如,假定输入的字符串为"asdasasdfgasdaszx67asdmklo",子字符串为"as",函数返回值是6。

  函数ReadWrite()实现从文件IN.dat中读取两个字符串,并调用函数findStr(),最后,把结果输出到文件OUT.dat中。

  【答案】

  intfindStr(char*str,char*substr)

  {intn;

  char*p,*r;

  n=0;

  while(*str)

  {p=str;

  r=substr;

  while(*r)

  if(*r==*p)

  {r++;

  p++;

  }

  else

  {break;

  }

  if(*r=='\0')

  n++;

  str++;

  }

  returnn;

  }

  8.请编写函数CountValue(),它的功能是:

求n以内(不包括n),同时能被3与7整除的所有自然数之和的平方根s,并作为函数值返回。

  主函数最后调用函数progReadWrite()从IN.dat文件中读取10组数据,分别得出结果,且把结果输出到文件OUT.dat中。

  例如,若n为1000时,函数值应为:

s=153.909064。

  【答案】

  doublecountValue(intn)

  {doublexy=0.0;

  inti;

  for(i=1;i<>

  if(i%3==0&&i%7==0)

  xy+=i;

  xy=sqrt((double)xy);

  returnxy;

  }

  9已知在文件IN.dat中存有N个(N<200)实数,函数RData()读取这N个实数并存入数组original中。

请编写函数CalValue(),要求实现的功能有:

①求出这N个实数的平均值(aver);②分别求出这N个实数的整数部分之和(sumint)以及小数部分之和(sumdec),最后调用函数WData()把所求的结果输出到文件OUT.dat中。

  【答案】

  voidCalValue(void)

  {inti;

  doublex,sum=0;

  for(i=0;i<>

  {sumint=sumint+(int)original[i];

  x=original[i]-(int)original[i];

  sumdec=sumdec+x;

  sum=sum+original[i];

  }

  aver=sum/MAXNUM;

  }

10.已知数据文件IN.dat中存有300个四位数,并已调用读函数Rdata()把这些数存入数组a中,请编写函数primeNum(),其功能是:

求出所有这些四位数中素数的个数count,再把所有满足此条件的四位数依次存入数组b中,然后对数组b的四位数按从小到大的顺序进行排序。

最后调用写函数Wdata(),把结果输出到OUT.dat文件中。

  例如,5591是素数,则该数满足条件存入数组b中,且个数count=count+1。

9812是非素数,则该数不满足条件,不存入数组b中,count值也不加1。

  【答案】

  voidprimeNum()

  {intj,i,value;

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

  if(isP(a[i]))

  {b[count]=a[i];

  count++;

  }

  for(i=0;i<>

  for(j=i+1;j<>

  if(b[i]>b[j])

  {value=b[i];

  b[i]=b[j];

  b[j]=value;

  }

  }

  11.下列程序的功能是:

把s字符串中的所有字符左移一个位置,字符串中的第一个字符移到最后。

请编写函数change(char*s)实现程序要求,最后调用函数readwriteDAT()从IN.dat文件中读取50组数据,分别得出结果,且把结果输出到OUT.dat文件中。

  例如,s字符串中原有内容为:

Mn.123xyZ,调用该函数后结果为:

n.123xyZM。

  【答案】

  voidchange(char*s)

  {inti,strl;

  charch;

  strl=strlen(s);

  ch=*s;

  for(i=0;i<>

  *(s+i)=*(s+i+1);

  *(s+strl-1)=ch;

  }

  12.下列程序的功能是:

找出所有100以内(含100)满足i、i+4、i+10都是素数的整数i(i+10也在100以内)的个数count以及这些i之和sum。

请编写函数primeNum()实现程序要求的功能,最后调用函数writeDat(),把结果count和sum输出到文件OUT.dat中。

  【答案】

  voidprimeNum()

  {inti;

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

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

  {count++;

  sum+=i;

  }

  }

13.函数Rdata()实现从文件IN.dat中读取一篇英文文章存入到字符串数组string中,请编写ConvertCharD()函数,其功能是:

以行为单位把字符串中的所有小写字母改写成该字母的上一个字母,如果是字母a,则改写成字母z。

大写字母仍为大写字母,小写字母仍为小写字母,其他字符不变,最后把已处理的字符串仍按行重新存入字符串数组string中。

最后调用函数Wdata(),把结果string输出到文件OUT.dat中。

  例如,原文:

Adb.Bcdza

  abck.LLhj

  结果:

Aca.Bbcyz

  zabj.LLgi

  原始数据文件存放的格式是:

每行的宽度均小于80个字符。

  【答案】

  voidConvertCharD(void)

  {inti;

  char*pf;

  for(i=0;i<>

  {pf=string[i];

  while(*pf)

  {if(*pf=='a')

  *pf='z';

  elseif(*pf>='b'&&*pf<='z')

  *pf-=1;

  pf++;

  }

  }

  }

  14.请编写函数countValue(),它的功能是:

求出1~1000之内能被7或11整除但不能同时被7或11整除的所有整数,将它们放在数组a中,并通过n返回这些数的个数。

主函数最后调用函数Wdata()把计算结果输出到OUT.dat中。

  【答案】

  voidcountValue(int*a,int*n)

  {inti;

  *n=0;

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

  if(i%7==0&&i%11)

  {*a=i;

  *n=*n+1;

  a++;

  }

  elseif(i%7&&i%11==0)

  {*a=i;

  *n=*n+1;

  a++;

  }

  }

  15.已知数据文件IN.dat中存有300个四位数,并已调用读函数Rdata()把这些数存入数组a中,请编写函数primeCal(),其功能是:

求出这些四位数中素数的个数count,再求出所有满足此条件的四位数的平均值Ave1以及不满足此条件的四位数的平均值Ave2。

最后调用写函数Wdata(),把结果count、Ave1、Ave2输出到OUT.dat文件中。

  例如,5591是素数,则该数满足条件计算平均值Ave1,且个数count=count+1。

9812是非素数,则该数不满足条件计算平均值Ave2。

  【答案】

  voidprimeCal()

  {inti;

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

  if(isP(a[i]))

  {Ave1+=a[i];

  count++;

  }

  else

  {Ave2+=a[i];

  }

  Ave1=Ave1/count;

  Ave2=Ave2/(300-count);

  }

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 小学教育 > 学科竞赛

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1