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

  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[i].name, sell[j].name) < 0)


  { temp = sell[i];


  sell[i] = sell[j];


  sell[j] = temp;


  }


  else if (strcmp(sell[i].name, sell[j].name) == 0)


  { if (sell[i].sum < sell[j].sum)


  { temp = sell[i];


  sell[i] = sell[j];


  sell[j] = 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[i]);


  for (j=1; j

  for (k=j+2; k

  if (str[i][j] > str[i][k])


  { ch = str[i][j];


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


  str[i][k] = 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[i] > a[j])


  { flag = 1;


  }


  else


  { flag = 0;


  break;


  }


  if (flag==1 && a[i]%2==0)


  { b[count] = a[i];


  count++;


  }


  }


  for (i=0; i

  for (j=i+1; j

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


  { flag = b[i];


  b[i] = b[j];


  b[j] = flag;


  }


  }

就业数据资源平台