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

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

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

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

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

  if(n>

=k)

  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;

199;

  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]<

original[j])

10;

  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;

99;

100;

  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<

sell[j].sum)

 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;

>

  {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;

  {strl=strlen(str[i]);

  for(j=0;

  for(k=j+1;

k<

  if(str[i][j]<

str[i][k])

  {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中。

  voidStrCharMove(void)

  {inti,j,strl;

  {strl=strlen(original[i]);

  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'

  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;

  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)

  doublex,sum=0;

  {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;

300;

  if(isP(a[i]))

  {b[count]=a[i];

  count++;

  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;

  strl=strlen(s);

  ch=*s;

  *(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中。

  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

  voidConvertCharD(void)

  {pf=string[i];

  while(*pf)

  {if(*pf=='

a'

  *pf='

z'

;

  elseif(*pf>

='

b'

&

*pf<

  *pf-=1;

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

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

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

  voidcountValue(int*a,int*n)

  *n=0;

=1000;

  if(i%7==0&

i%11)

  {*a=i;

  *n=*n+1;

  a++;

  elseif(i%7&

i%11==0)

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

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

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

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

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

  voidprimeCal()

  {Ave1+=a[i];

  {Ave2+=a[i];

  Ave1=Ave1/count;

  Ave2=Ave2/(300-count);

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

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

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

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