就业数据资源平台
当前位置:首页 > 数据库技术
2012年计算机三级数据库上机题及参考答案(4)

 22.下列轨范的功能是:把str字符串中的所有字母改写成该字母的下矣闽字母,字母z改写成字母a。要求大写字母仍为大写字母,小写字母仍为小写字母,其他字符不做改变。

  请编写函数CharChange(char*str)实现轨范要求,最后挪用函数RWData()从IN.dat文件中篡夺50组数据,分袂得出结不美观,并把结不美观输出到文件OUT.dat中。


  例如,str字符串华夏有的内容为:Mn.123Zxy,则挪用该函数后,结不美观为:No.123Ayz。


  【谜底】


  void CharChange(char *str)


  { while (*str)


  { if (*str=='z' || *str=='Z')


  *str -= 25;


  else if (isalpha(*str))


  *str += 1;


  str++;


  }


  }


  23.已知在文件IN.dat中存有100个产物发卖记实,每个产物发卖记实由产物代码code(字符型4位)、产闻缦沱称name(字符型10位)、单价uprice(整型)、数目amount(整型)、金额sum(长整型)5部门组成。此鱿脯金额=单价×数目。函数RData()篡夺这100个发卖记实并存入结构数组sell中。请编写AscendSort()函数,其功能是:按产闻缦沱称巨细到猛进行枚举,若产闻缦沱称相等,则按金额巨细到猛进行枚举,最终枚举结不美观仍存入结构数组sell中。最后挪用函数WData(),把结不美观输出到文件OUT.dat中。


  【谜底】


  void AscendSort()


  { int i, j;


  PRO temp;


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


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


  if (strcmp(sell.name, sell.name) > 0)


  { temp = sell;


  sell = sell;


  sell = temp;


  }


  else if (strcmp(sell.name, sell.name) == 0)


  { if (sell.sum > sell.sum)


  { temp = sell;


  sell = sell;


  sell = temp;


  }


  }


  }


  24.已知数据文件IN.dat中存有200个四位数,并已挪用读函数RData()把这些数存入数组a中,请编写函数evenVal(),其功能是:若一个四位数的千位上的数字值小于等于百位上的数字值,百位上的数字值小于等于十位上的数字值,以及十位上的数字值小于等于个位上的数字值,而且该四位数是偶数,则统计出知足此前提的个数count,并把这些四位数按巨细到大的挨次存入数组b中。最后挪用写函数WData(),把结不美观count以及数组b中合适前提的四位数输出到OUT.dat文件中。


  轨范中已界说数组a,、b,已界说变量count。


  【谜底】


  void evenVal()


  { int i, j;


  int a1, a2, a3, a4, k;


  for (i=0; i

  { a1 = a/1000;


  a2 = a%1000/100;


  a3 = a%100/10;


  a4 = a%10;


  if ((a1 <= a2) && (a2 <= a3) && (a3 <= a4) && (a%2 == 0))


  { b = a;


  count++;


  }


  }


  for (i=0; i

  for (j=i+1; j

  if (b > b)


  { k = b;


  b = b;


  b = k;


  }


  }

就业数据资源平台