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

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


  }


  }


  }


  24.已知数据文件IN.dat中存有200个四位数,并已调用读函数RData()把这些数存入数组a中,请编写函数evenVal(),其功能是:若一个四位数的千位上的数字值小于等于百位上的数字值,百位上的数字值小于等于十位上的数字值,以及十位上的数字值小于等于个位上的数字值,并且该四位数是偶数,则统计出满足此条件的个数count,并把这些四位数按从小到大的顺序存入数组b中。最后调用写函数WData(),把结果count以及数组b中符合条件的四位数输出到OUT.dat文件中。


  程序中已定义数组a[200],、b[200],已定义变量count。


  【答案】


  void evenVal()


  { int i, j;


  int a1, a2, a3, a4, k;


  for (i=0; i

  { a1 = a[i]/1000;


  a2 = a[i]%1000/100;


  a3 = a[i]%100/10;


  a4 = a[i]%10;


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


  { b[count] = a[i];


  count++;


  }


  }


  for (i=0; i

  for (j=i+1; j

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


  { k = b[i];


  b[i] = b[j];


  b[j] = k;


  }


  }

就业数据资源平台