为了正常的体验网站,请在浏览器设置里面开启Javascript功能!

全国计算机等级考试三级数据库技术上机南开100题

2012-04-07 49页 pdf 256KB 36阅读

用户头像

is_029109

暂无简介

举报
全国计算机等级考试三级数据库技术上机南开100题 1.请编写一个函数 jsValue(int m,int k,int xx[]),该函数的功能是:将大于整数 m且紧靠 m 的 k个素数存入数组 xx传回。 例如:若输入 17 5 则应输出:19,23,29,31,37。 void jsValue(int m,int k,int xx[]) { int i,j,s=0; for(i=m+1;k>0;i++) { for(j=2;j
全国计算机等级考试三级数据库技术上机南开100题
1.请编写一个函数 jsValue(int m,int k,int xx[]),该函数的功能是:将大于整数 m且紧靠 m 的 k个素数存入数组 xx传回。 例如:若输入 17 5 则应输出:19,23,29,31,37。 void jsValue(int m,int k,int xx[]) { int i,j,s=0; for(i=m+1;k>0;i++) { for(j=2;j
目 3函数读取一英文章存入到数组 xx中;请编制函数 StrOR( ),其函数的功能是:以 行为单位依次把字符串中所有小写字母 o左边的字符串内容移到该串的右边存放,然后把小 写字母 o删除,余下的字符串内容移到已处理字符串的左边存放,之后把已处理的字符串仍 按行重新存入字符串数组 xx中。原始数据文件存放的格式是:每行的宽度均小于 80个字符, 含标点符号和空格。 void StrOR(void) { int i; char a[80],*p; for(i=0;i单词
进行 倒排。最后把已处理的字符串(应不含标点符号)仍按行重新存入字符串数组 xx中,最后 调用函数 writeDat()把结果 xx输出到文件 OUT6.DAT中。 例如:原文:You He Me I am a student. 结果:Me He You student a am I 原始数据文件存放的格式是:每行的宽度均小于 80个字符,含标点符号和空格。 部分源程序存在文件 prog1.c中。 请勿改动主函数 main()、读数据函数 ReadDat()和输出数据函数 writeDat()的内容。 void StrOL(void) { int i,j,k,s,m,strl; char str[80]; for(i=0;i=0;j--) { if(isalpha(xx[i][j])) k++; else { for(m=1;m<=k;m++) str[s++]=xx[i][j+m]; k=0; } if(!isalpha(xx[i][j])) str[s++]=' '; } for(m=1;m<=k;m++) str[s++]=xx[i][j+m]; str[s]='\0'; strcpy(xx[i],str); } } ★题目 5(无忧 id 8题) 在文件 in.dat中有 200个正整数,且每个数均在 1000至 9999之间。函数 ReadDat()读取这 200个数存放到数组 aa中。请编制函数 jsSort(),其函数的功能是:要求按每个数的后三位 的大小进行升序排列,然后取出满足此条件的前 10个数依次存入数组 bb中,如果后三位的 数值相等,则按原先的数值进行降序排列。最后调用函数WriteDat()把结果 bb输出到文件 out.dat中。 例:处理前 6012 5099 9012 7025 8088 处理后 9012 6012 7025 8088 5099 部分源程序存在文件 prog1.c中。 请勿改动主函数 main()、读数据函数 ReadDat()和输出数据函数WriteDat()的内容。 void jsSort() { int i,j,data; for(i=0;i<199;i++) for(j=i+1;j<200;j++) if(aa[i]%1000>aa[j]%1000||aa[i]%1000==aa[j]%1000&&aa[i]aa[j]) {data=aa[i];aa[i]=aa[j];aa[j]=data;} for(i=0;i<10;i++) bb[i]=aa[i]; } ★题目 7(无忧 id 15题) 已知在文件 IN.DAT中存有 100个产品销售,每个产品销售记录由产品代码 dm(字符型 4位),产品名称 mc(字符型 10位),单价 dj(整型),数量 sl(整型),金额 je(长整型)五部分组 成。其中:金额=单价*数量计算得出。函数 ReadDat()是读取这 100个销售记录并存入结构 数组 sell中。请编制函数 SortDat(),其功能要求:按产品代码从大到小进行排列,若产品代 码相同,则按金额从大到小进行排列,最终排列结果仍存入结构数组 sell中,最后调用函数 WriteDat()把结果输出到文件 OUT6.DAT中。 void SortDat() {int I,j; PRO xy; for(I=0;I<99;I++) for(j=I+1;j<100;j++) if(strcmp(sell[I].dm,sell[j].dm)<0||strcmp(sell[I].dm,sell[j].dm)==0&&sell[I].je130) continue; else xx[i][j]=xx[i][j]*11%256; } 题目 9(无忧 id 28;id 124题;捷成 id 16题) 函数 ReadDat()实现从文件 IN.DAT中读取一篇英文文章存入到字符串数组 xx中,请编制函 数 SortCharD(),其函数的功能是:以行为单位对字符按从大到小的顺序进行排序,排序后 的结果仍按行重新存入字符串数组 xx 中,最后调用函数 writeDat()把结果 xx 输出到文件 OUT2.DAT中。 例:原文:dAe,BfC. CCbbAA 结果:fedCBA. bbCCAA 原始数据文件存放的格式是:每行的宽度均小于 80个字符,含标点符号和空格。 void SortCharD(void) {int I,j,k,strl; char ch; for(I=0;I='a'&&xx[i][j]<='y') xx[i][j]+=1; } } 题目 11(无忧 id 93题) 程序 prog1.c的功能是:把 s 字符串中的所有字母改写成该字母的下一个字母,字母 z改写 成字母 a。要求大写字母仍为大写字母,小写字母仍为小写字母,其它字符不做改变。 请考生编写函数 chg(char *s)实现程序要求,最后调用函数 readwriteDAT( )把结果输 出到文件 bc1.out中。 例如:s 字符串中原有的内容为:Mn.123Zxy,则调用该函数后,结果为:No.123Ayz。 void chg(char *s) {while(*s) if(*s=='z'||*s=='Z') {*s-=25; s++;} else if(*s>='a'&&*s<='y') {*s+=1;s++;} else if(*s>='A'&&*s<='Y') {*s+=1;s++;} else s++; } ★题目 12已知在文件 IN.DAT中存有 100个产品销售记录,每个产品销售记录由产品代码 dm(字符型 4位),产品名称 mc(字符型 10位),单价 dj(整型),数量 sl(整型),金额 je(长整 型)五部分组成。其中:金额=单价*数量计算得出。函数 ReadDat()是读取这 100个销售记录 并存入结构数组 sell中。请编制函数 SortDat(),其功能要求: 按产品名称从小到大进行排列,若产品名称相等,则按金额从小到大进行排列,最终排列结 果仍存入结构数组 sell中,最后调用函数WriteDat()把结果输出到文件 OUT5.DAT中。 部分源程序存在文件 prog1.c中。 void SortDat() {int I,j; PRO xy; for(I=0;I<99;I++) for(j=I+1;j<100;j++) if(strcmp(sell[I].mc,sell[j].mc)>0||strcmp(sell[I].mc,sell[j].mc)==0&&sell[I].je>sell[j].je) {xy=sell[I];sell[I]=sell[j];sell[j]=xy;} } 题目 13(无忧 id 81题(按金额从小到大进行排列)) 已知在文件 IN.DAT中存有 100个产品销售记录,每个产品销售记录由产品代码 dm(字符型 4位),产品名称 mc(字符型 10位),单价 dj(整型),数量 sl(整型),金额 je(长整型)五部分组 成。其中:金额=单价*数量计算得出。函数 ReadDat()是读取这 100个销售记录并存入结构 数组 sell中。请编制函数 SortDat(),其功能 要求:按产品代码从小到大进行排列,若产品代码相等,则按金额从大到小进行排列,最终 排列结果仍存入结构数组 sell中,最后调用函数WriteDat()把结果输出到文件OUT9.DAT中。 void SortDat() {int I,j; PRO xy; for(I=0;I<99;I++) for(j=I+1;j<100;j++) if(strcmp(sell[I].dm,sell[j].dm)>0||strcmp(sell[I].dm,sell[j].dm)==0&&sell[I].jea[j]&&a[I]%2) flag=1; else {flag=0;break;} if(flag==1) {b[cnt]=a[I]; cnt++;} } for(I=0;Ib[j]) {flag=b[I];b[I]=b[j];b[j]=flag;} } 题目 15(无忧 id 150 题) 已知数据文件 IN.DAT中存有 200个四位数,并已调用读函数 readDat()把这些数存入数组 a 中,请考生编制一函数 jsVal(),其功能是:若一个四位数的千位数字上的值小于等于百位数 字上的值,百位数字上的值小于等于十位数字上的值,以及十位数字上的值小于等于个位数 字上的值,并且原四位数是偶数,则统计出满足此条件的个数 cnt并把这些四位数按从小到 大的顺序存入数组 b中,最后调用写函数 writeDat()把结果 cnt 以及数组 b中符合条件的四 位数输出到 OUT.DAT文件中。 注意:部分源程序存在文件 prog1.c中。 程序中已定义数组:a[200],b[200],已定义变 量:cnt 请勿改动数据文件 IN.DAT中的任何数据、主函数 main()、读函数 readDat()和写函数 writeDat()的内容。 void jsVal() {int I,j; int qw,bw,sw,gw; for (I=0;Ib[j]) {qw=b[I];b[I]=b[j];b[j]=qw;} } ★题目 16函数 ReadDat()实现从文件 IN.DAT中读取一篇英文文章存入到字符串数组 xx中, 请编制函数 StrCharJR(),其函数的功能是:以行为单位把字符串中所有字符的 ASCII值右 移 4位,然后把右移后的字符 ASCII值再加上原字符的 ASCII值,得到新的字符仍存入原 字符串对应的位置上。最后把已处理的字符串仍按行重新存入字符串数组 xx中,最后调用 函数 writeDat()把结果 xx输出到文件 OUT8.DAT中 原始数据文件存放的格式是:每行的宽度均小于 80个字符,含标点符号和空格。 void StrCharJR() {int i,j; for(i=0;i>4); } 题目 17:函数 READDAT()实现从文件 IN.DAT中读取一篇英文文章存入到字符串数组 XX中;请编制函数 CHA(),其函数功能是:以行为单位把字符串中的第一个字符的 ASCII值加 第二个字符的ASCII值,得到第一个亲朋字符,第二个字符的ASCII值加第三个字符的ASCII 值,得到第二个新字符,依此类推一直处理到最后第二个字符,最后一个字符的 ASCII值 加原第一个字符的 ASCII值,得到最后一个新的字符,得到的新字符分别存放在原字符串 对应的位置上。最后把已处理的字符串逆转后按行重新存入字符串数组 XX中,最后调用函 数WRITEDAT()把结果 XX输出到文件OUT9.DAT中.原始数据文件存放的格式是:每行的宽 度均小于 80个字符,含标点符号和空格. void ChA(void) { int i,j; char ch; for(i=0;i=0.000001); return x1; } ★题目 22请编写函数 countValue(),它的功能是:求 n以内(不包括 n)同时能被 3与 7整 除的所有自然数之和的平方根 s,并作为函数值返回,最后结果 s输出到文件 out.dat中。 例如若 n为 1000时,函数值应为:s=153.909064。 部分源程序存在文件 prog1.c中。 double countValue(int n) { int i; double s=0.0; for(i=1;i=half) return 1; else return 0; } ★题目 26(无忧 id 37 题) 已知在文件 IN.DAT中存有若干个(个数<200)四位数字的正整数,函数 ReadDat()读取这 若干个正整数并存入数组 xx中。请编制函数 CalValue(),其功能要求:1、求出这文件中共 有多少个正整数 totNum;2、求这些数右移 1位后,产生的新数是偶数的数的个数 totCnt, 以及满足此条件的这些数(右移前的值)的算术平均值 totPjz,最后调用函数 writeDat()把所求 的结果输出到文件 OUT.DAT中。 void CalValue(void) {int i,data,yy[MAXNUM]; for(i=0;i0) yy[totNum++]=xx[i]; for(i=0;i>1; if(data%2==0){totCnt++;totPjz+=yy[i];} } if(totCnt==0) totPjz=0; else totPjz/=totCnt; } ★题目 27(无忧 id 57 题) 已知数据文件 in.dat 中存有 300个四位数,并已调用读函数 ReadDat()把这些数存入数组 a 中,请编制一函数 jsValue(),其功能是:求出千位数上的数减百位数上的数减十位数上的数 减个位数上的数大于零的个数 cnt,再把所有满足此条件的四位数依次存入数组 b中,然后 对数组 b的四位数按从小到大的顺序进行排序,最后调用写函数 writeDat()把结果输出到 out.dat文件。 例如:9123,9-1-2-3>0,则该数满足条件存入数组 b中,且个数 cnt=cnt+1。 9812,9-8-1-2>0,则该数不满足条件忽略。 jsValue() { int i,j,qw,bw,sw,gw; for(i=0;i<300;i++) { qw=a[i]/1000; bw=a[i]/100%10; sw=a[i]%100/10; gw=a[i]%10; if(qw-bw-sw-gw>0) b[cnt++]=a[i]; } for(i=0;ib[j]) { qw=b[i]; b[i]=b[j]; b[j]=qw;} } ★题目 28(无忧 id 138 题) 已知数据文件 IN.DAT中存有 200个四位数,并已调用读函数 readDat()把这些数存入数组 a 中,请考生编制一函数 jsVal(),其功能是:把千位数字和十位数字重新组成一个新的十位数 ab(新十位数的十位数字是原四位数的千位数字,新十位数的个位数字是原四位数的十位数 字),以及把个位数字和百位数字组成另一个新的十位数 cd(新十位数的十位数字是原四位 数的个位数字,新十位数的个位数字是原四位数的百位数字),如果新组成的两个十位数 ab-cd>=0且 ab-cd<=10且两个数均是奇数,同时两个新数的十位数字均不为零,则将满足此 条件的四位数按从大到小的顺序存入数组 b中,并要计算满足上述条件的四位数的个数 cnt。 最后 main()函数调用写函数 writeDat( )把结果 cnt 以及数组 b中符合条件的四位数输出到 OUT.DAT文件中。 void jsVal() {int I,j,thou,hun,ten,data,ab,cd; for(I=0;I<200;I++) {thou=a[I]/1000; hun=a[I]%1000/100; ten=a[I]%100/10; data=a[I]%10; ab=10*thou+ten; cd=10*data+hun; if((ab-cd)>=0&&(ab-cd)<=10&&ab%2==1&&cd%2==1&&ab>=10&&cd>=10) b[cnt++]=a[I]; } for(I=0;I=10且 ab-cd<=20且两个数均是偶数,同时两个新数的十位数字均不为零,则将满足 此条件的四位数按从大到小的顺序存入数组 b中,并要计算满足上述条件的四位数的个数 cnt。 void jsVal() { int i,j,qw,bw,sw,gw,ab,cd; for(i=0;i=10&&ab-cd<=20&&ab%2==0&&cd%2==0&&qw!=0&&gw!=0) b[cnt++]=a[i]; } for(i=0;ib[j]) {flag=b[I];b[I]=b[j];b[j]=flag;} } ★题目 31(无忧 id 17 题) 已知在文件 IN.DAT中存有 100个产品销售记录,每个产品销售记录由产品代码 dm(字符型 4位),产品名称 mc(字符型 10位),单价 dj(整型),数量 sl(整型),金额 je(长整型)五部分组 成。其中:金额=单价*数量计算得出。函数 ReadDat()是读取这 100个销售记录并存入结构 数组 sell中。请编制函数 SortDat(),其功能要求:按金额从大到小进行排列,若金额相同, 则按产品代码从大到小进行排列, 最终排列结果仍存入结构数组 sell 中,最后调用函数 WriteDat() 把结果输出到文件 OUT4.DAT中。 部分源程序存在文件 prog1.c中。 void SortDat() {int I,j; PRO xy; for(I=0;I<99;I++) for(j=I+1;j<100;j++) if(sell[I].jesell[j].je) {xy=sell[I];sell[I]=sell[j];sell[j]=xy;} } ★题目 33(无忧 id 61 题) 请编制函数 ReadDat()实现从文件 IN.DAT中读取 1000个十进制整数到数组 xx中;请编制 函数 Compute()分别计算出 xx中偶数的个数 even,奇数的平均值 ave1,偶数的平均值 ave2 以及方差 totfc的值,最后调用函数WriteDat()把结果输出到 OUT.DAT文件中。 计算方差的公式如下: N 2 totfc=1/N∑(xx[i]-ave2) i=1 设 N为偶数的个数,xx[i]为偶数,ave2为偶数的平均值。 原始数据文件存放的格式是:每行存放 10个数,并用逗号隔开。(每个数均大于 0且小 于等于 2000) #include #include #include #define MAX 1000 int xx[MAX],odd=0,even=0; double ave1=0.0,ave2=0.0,totfc=0.0; void WriteDat(void); int ReadDat(void) {int i; FILE *fp; if((fp=fopen("IN.DAT","r"))==NULL) return 1; /*********编制函数 ReadDat()的部分************/ for(i=0;i int cnt, sum ; void countValue() { int i,j,bw,sw,gw; for(i=100;i<1000;i++) { bw=i/100; sw=i%100/10; gw=i%10; for(j=2;j=M,这里 Sn=A1+A2+...+An,并依次把 n值存入数组单元 b[0],b[1]和 b[2]中,请编制 jsValue()函数来实现此功能, 最后调用函数 writeDat()把数组 b[]中的值输出到 out.dat文件中。 请勿改动主函数 main()和写函数 writeDat()的内容。 #include int b[3]; jsValue() {int a1=1,a2=1,a12,sn,k=2; sn=a1+a2; while(1) {a12=a1+2*a2; if(sn<100&&sn+a12>=100) b[0]=k; if(sn<1000&&sn+a12>=1000) b[1]=k; if(sn<10000&&sn+a12>=10000) {b[2]=k;break;} sn=sn+a12; a1=a2;a2=a12; k++; } } ★题目 36(无忧 id 5题) 函数 ReadDat()实现从文件 ENG.IN中读取一篇英文文章,存入到字符串数组 xx中;请编制 函数 encryptChar(),按给定的替代关系对数组 xx中的所有字符进行替代,仍存入数组 xx的 对应的位置上,最后调用函数WriteDat()把结果 xx输出到文件 pS6.DAT中。 替代关系:f(p)=p*11 mod 256(p是数组中某一个字符的 ASCII值,f(p)是计算后新字 符的 ASCII值),如果计算后 f(p)值小于等于 32或 f(p)对应的字符是数字 0至 9,则该字符 不变,否则将 f(p)所对应的字符进行替代。 部分源程序存在文件 prog1.c 中。原始数据文件存放的格式是:每行的宽度均小于 80 个字符。 void encryptChar() { int i,j; for(i=0;i='0'&&xx[i][j]*11%256<='9') continue; else xx[i][j]=xx[i][j]*11%256; } 题目 37(无忧 id 89 题) 函数 ReadDat()实现从文件 ENG.IN中读取一篇英文文章,存入到字符串数组 xx中;请编制 函数 encryptChar(),按给定的替代关系对数组 xx中的所有字符进行替代,仍存入数组 xx的 对应的位置上,最后调用函数WriteDat()把结果 xx输出到文件 PS7.DAT中。 替代关系:f(p)=p*11 mod 256(p是数组中某一个字符的 ASCII值,f(p)是计算后新字符的 ASCII值),如果原字符是大写字母或计算后 f(p)值小于等于 32,则该字符不变,否则将 f(p) 所对应的字符进行替代。 部分源程序存在文件 prog1.c中。原始数据文件存放的格式是:每行的宽度均小于 80个字符。 void encryptChar() { int i,j; for(i=0;i='A'&&xx[i][j]<='Z') continue; else xx[i][j]=xx[i][j]*11%256; } ★题目 38(无忧 id 81 题) 已知在文件 IN.DAT中存有 100个产品销售记录,每个产品销售记录由产品代码 dm(字符型 4位),产品名称 mc(字符型 10位),单价 dj(整型),数量 sl(整型),金额 je(长整型)五部分组 成。其中:金额=单价*数量计算得出。函数 ReadDat()是读取这 100个销售记录并存入结构 数组 sell中。请编制函数 SortDat(),其功能要求:按产品代码从小到大进行排列,若产品代 码相同,则按金额从小到大进行排列,最终排列结果仍存入结构数组 sell中,最后调用函数 WriteDat()把结果输出到文件 OUT6.DAT中 void SortDat() {int I,j; PRO xy; for(I=0;I<99;I++) for(j=I+1;j<100;j++) if(strcmp(sell[I].dm,sell[j].dm)>0||strcmp(sell[I].dm,sell[j].dm)==0&&sell[I].je>sell[j].je) {xy=sell[I];sell[I]=sell[j];sell[j]=xy;} } ★题目 39(无忧 id 63 题) 现有一个 10个人 100行的选票数据文件 IN.DAT,其数据存放的格式是每条记录的长度均为 10位,第一位示第一个人的选中情况,第二位表示第二个人的选中情况,依此类推 :内 容均为字符 0和 1,1表示此人被选中,0表示此人未被选中,全选或不选均为无效的选票。 给定函数 ReadDat()的功能是把选票数据读入到字符串数组 xx中。请编制函数 CountRs()来 统计每个人的选票数并把得票数依次存入 yy[0]到 yy[9]中。把结果 yy 输出到文件 OUT.DAT中。 void CountRs(void) { int i,j,count; for(i=0;i<100;i++) { count=0; for(j=0;j<10;j++) if(xx[i][j]=='1') count++; if(c
/
本文档为【全国计算机等级考试三级数据库技术上机南开100题】,请使用软件OFFICE或WPS软件打开。作品中的文字与图均可以修改和编辑, 图片更改请在作品中右键图片并更换,文字修改请直接点击文字进行修改,也可以新增和删除文档中的内容。
[版权声明] 本站所有资料为用户分享产生,若发现您的权利被侵害,请联系客服邮件isharekefu@iask.cn,我们尽快处理。 本作品所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用。 网站提供的党政主题相关内容(国旗、国徽、党徽..)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
热门搜索

历史搜索

    清空历史搜索