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

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

  【谜底】


  void SortDat()


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


  }


  }


  }


  41.


  函数RData()实现从文件IN.dat中篡夺20行数据存放到字符串数组str中(每行字符串长度均小于80)。请编写函数oddSort(),其功能是:以行为单元对字符串变量的下标为奇数的字符按其ASCII值巨细到大的挨次进行排序,排序后的结不美观仍按行从头存入字符串数组str中。最后挪用函数WData(),把结不美观str输出到OUT.dat文件中。


  例如,位置 0 1 2 3 4 5 6 7


  源字符串 h g f e d c b a


  则措置后字符串 h a f c d e b g


  【谜底】


  void oddSort()


  { int i, j, k, strl;


  char ch;


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


  { strl = strlen(str);


  for (j=1; j

  for (k=j+2; k

  if (str > str)


  { ch = str;


  str = str;


  str = ch;


  }


  }


  }


  42.已知数据文件IN.dat中存有200个四位数,并已挪用读函数RData()把这些数存入数组a中,请编写函数evenVal(),其功能是:依次从数组a中掏出一个四位数,如不美观该四位数持续大于该四位数以前的5个数且该数是偶数(该四位数页堪不满5个数,则不统计),则统计出知足此前提的个数count并把这些四位数按从大到小的挨次存入数组b中。最后挪用写函数WData(),把结不美观count以及数组b中合适前提的四位数输出到OUT.dat文件中。


  【谜底】


  void evenVal()


  { int i, j, flag = 0;


  for (i=5; i

  { for (j=i-5; j

  if (a > a)


  { flag = 1;


  }


  else


  { flag = 0;


  break;


  }


  if (flag==1 && a%2==0)


  { b = a;


  count++;


  }


  }


  for (i=0; i

  for (j=i+1; j

  if (b < b)


  { flag = b;


  b = b;


  b = flag;


  }


  }

就业数据资源平台