首页 考试吧论坛 Exam8视线 考试商城 网络课程 模拟考试 考友录 实用文档 求职招聘 论文下载
2011中考 | 2011高考 | 2012考研 | 考研培训 | 在职研 | 自学考试 | 成人高考 | 法律硕士 | MBA考试
MPA考试 | 中科院
四六级 | 职称英语 | 商务英语 | 公共英语 | 托福 | 雅思 | 专四专八 | 口译笔译 | 博思 | GRE GMAT
新概念英语 | 成人英语三级 | 申硕英语 | 攻硕英语 | 职称日语 | 日语学习 | 法语 | 德语 | 韩语
计算机等级考试 | 软件水平考试 | 职称计算机 | 微软认证 | 思科认证 | Oracle认证 | Linux认证
华为认证 | Java认证
公务员 | 报关员 | 银行从业资格 | 证券从业资格 | 期货从业资格 | 司法考试 | 法律顾问 | 导游资格
报检员 | 教师资格 | 社会工作者 | 外销员 | 国际商务师 | 跟单员 | 单证员 | 物流师 | 价格鉴证师
人力资源 | 管理咨询师考试 | 秘书资格 | 心理咨询师考试 | 出版专业资格 | 广告师职业水平
驾驶员 | 网络编辑
卫生资格 | 执业医师 | 执业药师 | 执业护士
会计从业资格考试会计证) | 经济师 | 会计职称 | 注册会计师 | 审计师 | 注册税务师
注册资产评估师 | 高级会计师 | ACCA | 统计师 | 精算师 | 理财规划师 | 国际内审师
一级建造师 | 二级建造师 | 造价工程师 | 造价员 | 咨询工程师 | 监理工程师 | 安全工程师
质量工程师 | 物业管理师 | 招标师 | 结构工程师 | 建筑师 | 房地产估价师 | 土地估价师 | 岩土师
设备监理师 | 房地产经纪人 | 投资项目管理师 | 土地登记代理人 | 环境影响评价师 | 环保工程师
城市规划师 | 公路监理师 | 公路造价师 | 安全评价师 | 电气工程师 | 注册测绘师 | 注册计量师
缤纷校园 | 实用文档 | 英语学习 | 作文大全 | 求职招聘 | 论文下载 | 访谈 | 游戏

2011年计算机等考三级数据库上机题及答案(11)

考试吧整理“2011年计算机等级三级数据库上机题及答案(11)”,方便考生备考!

  31.已知在文件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 (sell[i].sum < sell[j].sum)

  { temp = sell[i];

  sell[i] = sell[j];

  sell[j] = temp;

  }

  else if (sell[i].sum == sell[j].sum)

  { if (strcmp(sell[i].code, sell[j].code) < 0)

  { temp = sell[i];

  sell[i] = sell[j];

  sell[j] = temp;

  }

  }

  }

  32.请补充完整RData()函数,实现从文件IN.DET中读取1000个十进制整数到数组evennum中,请编写函数Compute()分别计算出evennum中奇数的个数odd,偶数的个数even,奇数的平均值ave1,偶数的平均值ave2以及所有偶数的方差totfc的值。最后调用函数WData(),把结果输出到OUT.dat文件中。

  计算方差的公式如下:

  其中:N为偶数的个数,evennum[i]为偶数,ave2为偶数的平均值。

  原始数据文件存放的格式是:每行存放10个数(每个数均大于0且小于等于2000),并用逗号隔开。

  【答案】

  void Compute(void)

  { int i, result[MAX];

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

  if (evennum[i]%2)

  { odd++;

  ave1 += evennum[i];

  }

  else

  { even++;

  ave2 += evennum[i];

  result[even-1] = evennum[i];

  }

  ave1 /= odd;

  ave2 /= even;

  for (i=0; i

  totfc += (result[i]-ave2)*(result[i]-ave2)/even;

  }

  33.下列程序的功能是:将一个正整数序列{K1,K2,…,K9}重新排列成一个新的序列。新序列中,比K1小的数都在K1的前面(左面),比K1大的数都在K1的后面(右面),要求编写函数NumSort()实现此功能。最后调用Wdata()函数将新序列输出到OUT.dat文件中。

  说明:在程序中已给出了10个序列,每个序列有9个正整数,并存入数组a[10][9]中,分别求出这10个新序列。

  例如:序列{6,8,9,1,2,5,4,7,3}

  经重排后成为{3,4,5,2,1,6,8,9,7}

  【答案】

  NumSort(int a[10][9])

  { int value, i, j, k, num;

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

  { value = a[i][0];

  for (j=0; j<9; j++)

  if (a[i][j] < value)

  { num = a[i][j];

  for (k=j; k>0; k--)

  a[i][k] = a[i][k-1];

  a[i][0] = num;

  }

  }

  }

  相关推荐:

  2011计算机等级三级数据库考前实训练习汇总

  考试吧策划:2011年计算机等级考试备考攻略

  2011年计算机等级考试三级数据库SQL语句大全

文章搜索
版权声明:如果计算机等级考试网所转载内容不慎侵犯了您的权益,请与我们联系800@exam8.com,我们将会及时处理。如转载本计算机等级考试网内容,请注明出处。