《全国计算机三级考试数据库技术上机练习题及答案.doc》由会员分享,可在线阅读,更多相关《全国计算机三级考试数据库技术上机练习题及答案.doc(12页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、全国计算机三级考试数据库技术上机练习题及答案(1)1.调用函数rwdata(),从IN.dat文件中读取10组数据(m和k值),并嵌套调用primenum函数分别得出array数组。请编写函数primenum(int m,int k,int array),该函数的功能是:将紧靠m的k个素数存入数组array并在屏幕上显示。最后把结果输出到文件OUT.dat中。例如,若输入3 9,则应输出5 7 11 13 17 19 23 29 31。注意:部分程序已经给出。请勿改动主函数main()和输出数据函数rwdata()的内容。【答案】void primenum(int m, int k, int
2、array) int value = m+1;int half, n = 0, i;while(1) half = value/2;for (i=2; i half) arrayn = value;n+;if (n = k)break;value+;2.在文件IN.dat中有200个正整数,且每个数均在10009999之间。函数RData()读取这200个数存放到数组original中。请编写函数numAscend(),其功能是:要求按每个数的后3位的大小进行升序排列,然后取出满足此条件的前10个数依次存入数组result中,如果后3位的数值相等,则按原先的数值进行降序排列。最后调用函数WDa
3、ta(),把结果result输出到文件OUT.dat中。例如,处理前:6012 5099 9012 7025 8088处理后:9012 6012 7025 8088 5099【答案】void numascend() int i, j, data;for (i=0; i199; i+)for (j=i+1; j originalj%1000) data = originali;originali = originalj;originalj = data;else if (originali%1000 = originalj%1000) if (originali originalj) data
4、= originali;originali = originalj;originalj = data;for (i=0; i10; i+)resulti = originali;3.已知文件IN.dat中存有100个产品销售记录,每个产品销售记录由产品代码code(字符型4位)、产品名称name(字符型10位)、单价uprice(整型)、数量amount(整型)、金额sum(长整型)5部分组成。其中:金额=单价数量。函数RData()读取这100个销售记录并存入结构数组sell中。请编写函数DescSort(),其功能要求:按产品代码从大到小进行排列,若产品代码相同,则按金额从大到小进行排列,
5、最终排列结果仍存入结构数组sell中,最后调用函数WData(),把结果输出到文件OUT.dat中。【答案】void DescSort() int i, j;PRO temp;for (i=0; i99; i+)for (j=i+1; j100; j+)if (strcmp(selli.code, sellj.code) 0) temp = selli;selli = sellj;sellj = temp;else if (strcmp(selli.code, sellj.code) = 0) if (selli.sum sellj.sum) temp = selli;selli = sell
6、j;sellj = temp;4.函数RData()实现从文件IN.dat中读取一篇英文文章,存入到字符串数组str中;请编写encryptChar()函数,其功能是:按给定的替代关系对数组str中的所有字符进行替代,仍存入数组str对应的位置上,最后调用函数WData(),把结果str输出到文件OUT.dat中。替代关系:f(p)=p*11 mod 256(p是数组中某一个字符的ASCII值,f(p)是计算后新字符的ASCII值),如果计算后f(p)值小于1等于32或大于130,则该字符不变,否则将f(p)所对应的字符进行替代。原始数据文件存放的格式是:每行的宽度均小于80个字符。【答案】v
7、oid encryptChar() int i;char *pf;for (i=0; i pf = stri;while (*pf != 0) if (*pf*11%25632)*pf = *pf*11%256;pf+;5.函数RData()实现从文件IN.dat中读取一篇英文文章存入到字符串数组str中,请编写函数DescSort(),其功能是:以行为单位对字符按从大到小的顺序进行排序,排序后的结果仍按行重新存入字符串数组str中,最后调用函数WData(),把结果str输出到文件OUT.dat中。原始数据文件存放的格式是:每行的宽度均小于80个字符(含标点符号和空格)。例如,原文:dAeB
8、fC.CcbbAA结果:fedCBA.cbbCAA【答案】void DescSort(void) int i, j, k, strl;char ch;for (i=0; i strl = strlen(stri);for (j=0; jfor (k=j+1; kif (strij 4;7.编写函数findStr(),其功能是:统计一个长度为2的子字符串在另一个字符串中出现的次数。例如,假定输入的字符串为asd asasdfg asd as zx67 asd mklo,子字符串为as,函数返回值是6。函数ReadWrite()实现从文件IN.dat中读取两个字符串,并调用函数findStr(),
9、最后,把结果输出到文件OUT.dat中。【答案】int findStr(char *str, char *substr) int n;char *p, *r;n = 0;while (*str) p = str;r = substr;while (*r)if (*r = *p) r+;p+;else break;if (*r = 0)n+;str+;return n;8.请编写函数CountValue(),它的功能是:求n以内(不包括n),同时能被3与7整除的所有自然数之和的平方根s,并作为函数值返回。主函数最后调用函数progReadWrite()从IN.dat文件中读取10组数据,分别得出
10、结果,且把结果输出到文件OUT.dat中。例如,若n为1000时,函数值应为:s=153.。【答案】double countValue(int n) double xy = 0.0;int i;for (i=1; iif (i%3=0 & i%7=0)xy += i;xy = sqrt(double)xy);return xy;9已知在文件IN.dat中存有N个(N200)实数,函数RData()读取这N个实数并存入数组original中。请编写函数CalValue(),要求实现的功能有:求出这N个实数的平均值(aver);分别求出这N个实数的整数部分之和(sumint)以及小数部分之和(su
11、mdec),最后调用函数WData()把所求的结果输出到文件OUT.dat中。【答案】void CalValue(void) int i;double x, sum = 0;for (i=0; i sumint = sumint+(int)originali;x = originali-(int)originali;sumdec = sumdec+x;sum = sum+originali;aver = sum/MAXNUM;10.已知数据文件IN.dat中存有300个四位数,并已调用读函数Rdata()把这些数存入数组a中,请编写函数primeNum(),其功能是:求出所有这些四位数中素数的
12、个数count,再把所有满足此条件的四位数依次存入数组b中,然后对数组b的四位数按从小到大的顺序进行排序。最后调用写函数Wdata(),把结果输出到OUT.dat文件中。例如,5591是素数,则该数满足条件存入数组b中,且个数count=count+1。9812是非素数,则该数不满足条件,不存入数组b中,count值也不加1。【答案】void primeNum() int j, i, value;for (i=0; i bj) value = bi;bi = bj;bj = value;11.下列程序的功能是:把s字符串中的所有字符左移一个位置,字符串中的第一个字符移到最后。请编写函数chan
13、ge(char*s)实现程序要求,最后调用函数readwriteDAT()从IN.dat文件中读取50组数据,分别得出结果,且把结果输出到OUT.dat文件中。例如,s字符串中原有内容为:Mn.123xyZ,调用该函数后结果为:n.123xyZM。【答案】void change(char*s) int i, strl; char ch;strl = strlen(s);ch = *s;for (i=0; i*(s+i) = *(s+i+1);*(s+strl-1) = ch;12.下列程序的功能是:找出所有100以内(含100)满足i、i+4、i+10都是素数的整数i(i+10也在100以内)
14、的个数count以及这些i之和sum。请编写函数primeNum()实现程序要求的功能,最后调用函数writeDat(),把结果count和sum输出到文件OUT.dat中。【答案】void primeNum() int i;for(i=2;i=b & *pf=z)*pf -= 1;pf+;14.请编写函数countValue(),它的功能是:求出11000之内能被7或11整除但不能同时被7或11整除的所有整数,将它们放在数组a中,并通过n返回这些数的个数。主函数最后调用函数Wdata()把计算结果输出到OUT.dat中。【答案】void countValue(int *a, int *n)
15、int i;*n = 0;for (i=1; i=1000; i+)if (i%7=0 & i%11) *a = i;*n = *n+1;a+;else if (i%7 & i%11=0) *a = i;*n = *n+1;a+;15.已知数据文件IN.dat中存有300个四位数,并已调用读函数Rdata()把这些数存入数组a中,请编写函数primeCal(),其功能是:求出这些四位数中素数的个数count,再求出所有满足此条件的四位数的平均值Ave1以及不满足此条件的四位数的平均值Ave2。最后调用写函数Wdata(),把结果count、Ave1、Ave2输出到OUT.dat文件中。例如,5
16、591是素数,则该数满足条件计算平均值Ave1,且个数count=count+1。9812是非素数,则该数不满足条件计算平均值Ave2。【答案】void primeCal() int i;for (i=0; i= half)return 1;elsereturn 0;17请补充程序,使得程序能实现以下功能:从文件IN.dat中读取200个整数至数组number中,求出奇数的个数cnt1和偶数的个数cnt2以及数组number下标为偶数的元素值的算术平均值ave(保留2位小数)。把结果cnt1、cnt2、ave输出到OUT.dat中。【答案】for (i=0, j=0, cnt1=0, cnt2
17、=0; i if (numberi%2)cnt1+;elsecnt2+;if (i%2 = 0)j += numberi;ave = (float)j/(N/2);18.函数Rdata()实现从文件IN.dat中读取一篇英文文章,存入到字符串数组string中,请编写函数CharRight(),其功能是:以行为单位把字符串中的最后一个字符的ASCII值右移4位后加倒数第二个字符的ASCII值,得到最后一个新的字符;倒数第二个字符的ASCII值右移4位后加倒数第三个字符的ASCII值,得到倒数第二个新的字符;依此类推,一直处理到第二个字符;第一个字符的ASCII值加原最后一个字符的ASCII值,
18、得到第一个新的字符。得到的新字符分别存放在原字符串对应的位置上,最后已处理的字符串仍按行重新存入字符串数组string中。最后调用函数Wdata(),把结果string输出到文件OUT.dat中。原始数据文件存放的格式是:每行的宽度均小于80个字符(含标点符号和空格)。【答案】void CharRight(void) int i, j, strl;char ch;for (i=0; i strl = strlen(stringi);ch = stringistrl-1;for (j=strl-1; j0; j-) stringij = 4;stringij += stringij-1;stri
19、ngi0 += ch;19.已知数据文件IN.dat中存有200个四位数,并已调用读函数rdata()把这些数存入数组a中,请编写函数evenvalue(),其功能是:如果四位数每位上的数字均是0、2、4、6或8,则统计出满足此条件的四位数的个数count,并把这些四位数按从大到小的顺序存入数组b中。最后main()函数调用写函数wdata(),把结果count以及数组b中符合条件的四位数输出到OUT.dat文件中。【答案】void evenvalue() int bb4;int i, j, k, flag;for (i=0; i200; i+) bb0 = ai/1000;bb1 = ai%
20、1000/100;bb2 = ai%100/10;bb3 = ai%10;for (j=0; j4; j+) if (bbj%2 = 0) flag = 1;else flag = 0;break;if (flag = 1) bcount = ai;count+;for (i=0; ifor (j=i+1; jif (bi =0)j-;if (j 0)continue;StrResultij = 0;strcpy(buf, &StrResultij+1);k = j = 0;while (StrResultij) while (StrResultij!=o & StrResultij)j+;i
21、f (!StrResultij) strcat(buf, &StrResultik);break;StrResultij = 0;strcat(buf, &StrResultik);j+;k = j;strcpy(StrResulti, buf);21.函数RData()实现从文件IN.dat中读取一篇英文文章并存入到字符串数组StrResult中,请编写函数StrRes(),其功能是:以行为单位对行中以空格或标点符号为分隔的所有单词进行倒排。最后把已处理的字符串(应不含标点符号)仍按行重新存入字符串数组StrResult中,最后调用函数WData(),把结果StrResult输出到文件OUT
22、.dat中。原始数据文件存放的格式是:每行的宽度均小于80个字符,含标点符号和空格。例如,原文:You He MeI am a student.结果:Me He Youstudent a am I【答案】char StrRes(void) int i, j, k, strl, l;for (i=0; ifor (j=0; j= 0) for (j=k; j=0; j-)ppj+1 = ppj;pp0 = StrResultli;k+;i-;strcat(ch, pp);strcpy(pp, );k = 0;if (i = 0) for (j=k; j=0; j-)ppj+1 = ppj;pp0
23、 = StrResultli;k+;i-;strcat(ch, pp);strcpy(pp, );k = 0;if (i 0)break;strcpy(StrResultl, ch);22.下列程序的功能是:把str字符串中的所有字母改写成该字母的下一个字母,字母z改写成字母a。要求大写字母仍为大写字母,小写字母仍为小写字母,其他字符不做改变。请编写函数CharChange(char*str)实现程序要求,最后调用函数RWData()从IN.dat文件中读取50组数据,分别得出结果,并把结果输出到文件OUT.dat中。例如,str字符串中原有的内容为:Mn.123Zxy,则调用该函数后,结果为
24、: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()函数,其功能
25、是:按产品名称从小到大进行排列,若产品名称相等,则按金额从小到大进行排列,最终排列结果仍存入结构数组sell中。最后调用函数WData(),把结果输出到文件OUT.dat中。【答案】void AscendSort() int i, j;PRO temp;for (i=0; i99; i+)for (j=i+1; j 0) temp = selli;sell i = sellj;sellj = temp;else if (strcmp(selli.name, sellj.name) = 0) if (selli.sum sellj.sum) temp = selli;selli = sellj;
26、sellj = temp;24.已知数据文件IN.dat中存有200个四位数,并已调用读函数RData()把这些数存入数组a中,请编写函数evenVal(),其功能是:若一个四位数的千位上的数字值小于等于百位上的数字值,百位上的数字值小于等于十位上的数字值,以及十位上的数字值小于等于个位上的数字值,并且该四位数是偶数,则统计出满足此条件的个数count,并把这些四位数按从小到大的顺序存入数组b中。最后调用写函数WData(),把结果count以及数组b中符合条件的四位数输出到OUT.dat文件中。程序中已定义数组a200,、b200,已定义变量count。【答案】void evenVal()
27、int i, j;int a1, a2, a3, a4, k;for (i=0; i a1 = ai/1000;a2 = ai%1000/100;a3 = ai%100/10;a4 = ai%10;if (a1 = a2) & (a2 = a3) & (a3 bj) k = bi;bi = bj;bj = k;25.已知a1 = a2、a2 = a3、a3 = a4、ai%2 = 0这4个条件同时成立,则ai就是要求下列程序的功能是:在三位整数(100999)中寻找符合条件的整数并依次从小到大存入数组中;该整数既是完全平方数,又有两个数字相同,例如144、676等。请编写函数SearchVal
28、()实现此功能,满足该条件的整数的个数通过所编写的函数返回。最后调用函数WData(),把结果输出到文件OUT.dat中。注意:部分源程序已给出。请勿改动主函数main()和写函数WData()的内容。【答案】searchVal(int bb) int i, a, b, c, cnt = 0;for (i=10; i*i0,则该数满足条件存入数组b中,且个数count=count+1。9812,9-8-1-20,则该数不满足条件,忽略。程序中已定义数组a300,b300;已定义变量count。【答案】void jsValue() int i, thou, hun, ten, data, j;f
29、or (i=0; i 0) bcount = ai;count+;for (i=0; ifor (j=i+1; jif (bi bj) data = bi;bi = bj;bj = data;27函数Rdata()实现从文件IN.dat中读取一篇英文文章存入到字符串数组string中,请编写函数CharLeft(),其功能是:以行为单位把字符串中所有字符的ASCII值左移4位,如果左移后,其字符的ASCII值小于等于32或大于100,则原字符保持不变,否则就把左移后的字符ASCII值再加上原字符ASCII值,得到新的字符仍存入原字符串对应的位置上。最后把已处理的字符串仍按行重新存入字符串数组string中,最后调用函数Wdata(),把结果string输出到文件OUT.dat中。原始数据文件存放的格式是:每行的宽度均小于80个字符(含标点符号和空格)。【答案】void CharLeft(void) int i, j, str;char ch;for (i=0; i str = strlen(stringi);for (j=0; j ch = stringij32 & ch=100)stringij += ch;
限制150内