2015年计算机三级数据库上机题及参考答案(7)
发布时间:2012/5/18 9:39:30 来源:城市网学院 编辑:ziteng
-
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[NextPage] 【谜底】
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;
}
}