三级数据库上机.docx
- 文档编号:11767124
- 上传时间:2023-06-02
- 格式:DOCX
- 页数:33
- 大小:24.13KB
三级数据库上机.docx
《三级数据库上机.docx》由会员分享,可在线阅读,更多相关《三级数据库上机.docx(33页珍藏版)》请在冰点文库上搜索。
三级数据库上机
素数
题目1(无忧id14、id27(提供isP()函数;捷成id23题)
请编写一个函数jsValue(intm,intk,intxx[]),该函数的功能是:
将大于整数m且紧靠m的k个素数存入数组xx传回。
最后调用函数writeDat()读取10组数据,分别得出结果且把结果输出到文件out.dat中。
部分源程序存在文件prog1.c中。
例如:
若输入175则应输出:
19,23,29,31,37。
请勿改动主函数main()和写函数writeDat()的内容。
#include
#include
voidreadwriteDat();
intisP(intm)
{inti;
for(i=2;i if(m%i==0)return0; return1; } voidnum(intm,intk,intxx[]) {ints=0; for(m=m+1;k>0;m++) if(isP(m)){xx[s++]=m;k--;} } main() {intm,n,xx[1000]; clrscr(); printf("\nPleaseentertwointegers: "); scanf("%d%d",&m,&n); num(m,n,xx); for(m=0;m printf("%d",xx[m]); printf("\n"); readwriteDat(); } voidreadwriteDat() {intm,n,xx[1000],i; FILE*rf,*wf; rf=fopen("in.dat","r"); wf=fopen("out.dat","w"); for(i=0;i<10;i++){fscanf(rf,"%d%d",&m,&n); num(m,n,xx); for(m=0;m fprintf(wf,"\n"); } fclose(rf); fclose(wf); } 无忧id14题(无isP()函数) #include voidjsValue(intm,intk,intxx[]) {inti,j,s=0; for(i=m+1;k>0;i++) {for(j=2;j if(i%j==0)break; if(i==j){xx[s++]=i;k--;} } } main() {intm,n,zz[100]; printf("\n请输入两个整数: "); scanf("%d%d",&m,&n); jsValue(m,n,zz); for(m=0;m printf("\n"); writeDat(); } writeDat() {intm,n,zz[100],i; FILE*in,*out; in=fopen("in.dat","r"); out=fopen("out.dat","w"); for(i=0;i<10;i++){fscanf(in,"%d%d",&m,&n); jsValue(m,n,zz); for(m=0;m fprintf(out,"\n"); } fclose(in); fclose(out); } 另一解法: voidnum(intm,intk,intxx[]) {intn=0,data=m+1; while(n data++;} } 四位数 ★题目2(无忧id143整数排序题) 已知数据文件IN.DAT中存有200个四位数,并已调用读函数readDat()把这些数存入数组a中, 请考生编制一函数jsVal(),其功能是: 如果四位数各位上的数字均是0或2或4或6或8, 则统计出满足此条件的个数cnt,并把这些四位数按从大到小的顺序存入数组b中。 最后main()函数调用写函数writeDat()把结果cnt以及数组b中符合条件的四位数输出到OUT.DAT文件中。 注意: 部分源程序存在文件prog1.c中。 程序中已定义数组: a[200],b[200],已定义变量: cnt 请勿改动数据文件IN.DAT中的任何数据、主函数main()、读函数readDat()和写函数writeDat()的内容。 #include #defineMAX200 inta[MAX],b[MAX],cnt=0; voidjsVal() {inti,j,qw,bw,sw,gw; for(i=0;i {qw=a[i]/1000;bw=a[i]/100%10; sw=a[i]%100/10;gw=a[i]%10; if(qw&&qw%2==0&&bw%2==0&&sw%2==0&&gw%2==0)b[cnt++]=a[i]; } for(i=0;i for(j=i+1;j if(b[i] } voidreadDat() {inti; FILE*fp; fp=fopen("in.dat","r"); for(i=0;i fclose(fp); } voidmain() {inti; readDat(); jsVal(); printf("满足条件的数=%d\n",cnt); for(i=0;i printf("\n"); writeDat(); } writeDat() {FILE*fp; inti; fp=fopen("out.dat","w"); fprintf(fp,"%d\n",cnt); for(i=0;i fclose(fp); } 字符串 ★☆题目3(无忧id133题;捷成id59、99字符串位置倒置题) 函数ReadDat()实现从文件IN.DAT中读取一篇英文文章存入到字符串数组xx中; 请编制函数StrOR(),其函数的功能是: 以行为单位依次把字符串中所有小写字母o左边的字符串内容 移到该串的右边存放,然后把小写字母o删除,余下的字符串内容移到已处理字符串的左边存放, 之后把已处理的字符串仍按行重新存入字符串数组xx中。 最后main()函数调用函数WriteDat() 把结果xx输出到文件OUT5.DAT中。 例如: 原文: nanyfield.Yucancreateanindex youhavethecorrectrecord. 结果: nanyfield.Yucancreateanindex rd.yuhavethecrrectrec 原始数据文件存放的格式是: 每行的宽度均小于80个字符,含标点符号和空格。 注意: 部分源程序存放在文件prog1.c中。 请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。 #include #include #include charxx[50][80]; intmaxline=0;/*文章的总行数*/ intReadDat(void); voidWriteDat(void); voidStrOR(void) {inti,righto,j,s,k; chartem[80]; for(i=0;i for(j=strlen(xx[i])-1;j>=0;j--) {k=0; memset(tem,0,80);/*初始化字符串数组tem*/ if(xx[i][j]=='o')/*如果当前字符为'o',进入以下语句*/ {righto=j;/*则将此字符中位置j的值赋给righto*/ for(s=righto+1;s tem[k++]=xx[i][s];/*从righto的下一跳开始将其后所有的字符都存入到tem中*/ for(s=0;s if(xx[i][s]! ='o')tem[k++]=xx[i][s];/*将不是字符'o'的字符全存入到tem中*/ strcpy(xx[i],tem);/*将当前已处理的字符重新存入当前行xx*/ } elsecontinue; } } voidmain() {clrscr(); if(ReadDat()){printf("数据文件IN.DAT不能打开! \n\007"); return; } StrOR(); WriteDat(); } intReadDat(void) {FILE*fp; inti=0; char*p; if((fp=fopen("IN.DAT","r"))==NULL)return1; while(fgets(xx[i],80,fp)! =NULL){p=strchr(xx[i],'\n'); if(p)*p=0; i++; } maxline=i; fclose(fp); return0; } voidWriteDat(void) {FILE*fp; inti; clrscr(); fp=fopen("OUT5.DAT","w"); for(i=0;i fprintf(fp,"%s\n",xx[i]); } fclose(fp); } 解法二: voidStrOR(void) {inti; chara[80],*p; for(i=0;i {p=strchr(xx[i],'o'); while(p) {memset(a,0,80); memcpy(a,xx[i],p-xx[i]); strcpy(xx[i],p+1); strcat(xx[i],a); p=strchr(xx[i],'o'); } } } 解法三: voidStrOR(void) {inti,j;charyy[80],*p; for(i=0;i for(j=0;j if(xx[i][j]=='o') {p=&xx[i][j+1]; strcpy(yy,p);/*将指针p所指向的字符串拷贝到字符串yy中去*/ strncat(yy,xx[i],j);/*将字符串xx[i]中前j个字符连接到yy中*/ strcpy(xx[i],yy);/*将字符串yy重新拷贝到字符串xx[i]中去*/ j=0;/*开始下一次的扫描。 */ } } 相关库函数解释: char*strncat(char*dest,constchar*src,size_tmaxlen) 功能: 将字符串src中前maxlen个字符连接到dest中 相关头文件: string.h char*strcpy(char*dest,constchar*src) 功能: 将字符串src拷贝到字符串dest中去 相关头文件: string.h 销售记录 ★题目7(无忧id15结构体操作题)) 已知在文件IN.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位), 产品名称mc(字符型10位),单价dj(整型),数量sl(整型),金额je(长整型)五部分组成。 其中: 金额=单价*数量计算得出。 函数ReadDat()是读取这100个销售记录并存入结构数组sell中。 请编制函数SortDat(),其功能要求: 按产品代码从大到小进行排列,若产品代码相同, 则按金额从大到小进行排列,最终排列结果仍存入结构数组sell中,最后调用函数WriteDat()把 结果输出到文件OUT6.DAT中。 部分源程序存在文件prog1.c中。 请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。 #include #include #include #include #include #defineMAX100 typedefstruct{chardm[5];/*产品代码*/ charmc[11];/*产品名称*/ intdj;/*单价*/ intsl;/*数量*/ longje;/*金额*/ }PRO; PROsell[MAX]; voidReadDat(); voidWriteDat(); voidSortDat() {inti,j; PROxy; 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 {xy=sell[i];sell[i]=sell[j];sell[j]=xy;} } voidmain() {memset(sell,0,sizeof(sell)); ReadDat(); SortDat(); WriteDat(); } voidReadDat() {FILE*fp; charstr[80],ch[11]; inti; fp=fopen("IN.DAT","r"); for(i=0;i<100;i++){fgets(str,80,fp); memcpy(sell[i].dm,str,4); memcpy(sell[i].mc,str+4,10); memcpy(ch,str+14,4);ch[4]=0; sell[i].dj=atoi(ch); memcpy(ch,str+18,5);ch[5]=0; sell[i].sl=atoi(ch); sell[i].je=(long)sell[i].dj*sell[i].sl; } fclose(fp); } voidWriteDat(void) {FILE*fp; inti; fp=fopen("OUT6.DAT","w"); for(i=0;i<100;i++){printf("%s%s%4d%5d%5d\n",sell[i].dm,sell[i].mc,sell[i].dj,sell[i].sl,sell[i].je); fprintf(fp,"%s%s%4d%5d%5d\n",sell[i].dm,sell[i].mc,sell[i].dj,sell[i].sl,sell[i].je); } fclose(fp); } 字符替代 ★☆题目8(无忧id83字符替换题) 函数ReadDat()实现从文件ENG.IN中读取一篇英文文章,存入到字符串数组xx中;请编制函数encryptChar() ,按给定的替代关系对数组xx中的所有字符进行替代,仍存入数组xx的对应的位置上,最后调用函数 WriteDat()把结果xx输出到文件PS1.DAT中。 替代关系: f(p)=p*11mod256(p是数组中某一个字符的ASCII值,f(p)是计算后新字符的ASCII值), 如果计算后f(p)值小于等于32或大于130,则该字符不变,否则将f(p)所对应的字符进行替代。 部分源程序存 在文件prog1.c中。 原始数据文件存放的格式是: 每行的宽度均小于80个字符。 请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。 #include #include #include #include unsignedcharxx[50][80]; intmaxline=0;/*文章的总行数*/ intReadDat(void); voidWriteDat(void); voidencryptChar() {inti,j; for(i=0;i for(j=0;j if(xx[i][j]*11%256<=32||xx[i][j]*11%256>130)continue; elsexx[i][j]=xx[i][j]*11%256; } voidmain() {clrscr(); if(ReadDat()){printf("数据文件ENG.IN不能打开! \n\007"); return; } encryptChar(); WriteDat(); } intReadDat(void) {FILE*fp; inti=0; unsignedchar*p; if((fp=fopen("eng.in","r"))==NULL)return1; while(fgets(xx[i],80,fp)! =NULL){p=strchr(xx[i],'\n'); if(p)*p=0; i++; } maxline=i; fclose(fp); return0; } voidWriteDat(void) {FILE*fp; inti; fp=fopen("ps1.dat","w"); for(i=0;i fprintf(fp,"%s\n",xx[i]); } fclose(fp); } 解法二: voidencryptChar() {inti,j,k; for(i=0;i for(j=0;j {k=xx[i][j]*11%256; if(k<=32||k>130)continue; elsexx[i][j]=k; } } 解法三: voidencryptChar() {inti,j; unsignedcharch; for(i=0;i for(j=0;j {ch=xx[i][j]*11%256; if(ch<=32||ch>130)continue; elsexx[i][j]=ch; } } 解法四: voidencryptChar() {inti,j; char*p; for(i=0;i for(j=0;j {p=xx[i][j]*11%256; if(p<=32||p>130)continue; elsexx[i][j]=p; } } 解法五: voidencryptChar() {inti; char*pf; for(i=0;i {pf=xx[i]; while(*pf! =0) if(*pf*11%256<=32||*pf*11%256>130)pf++; else*pf++=*pf*11%256; } } 排列顺序 ★☆题目9(无忧id28;id124;捷成id16字符串排序题) 函数ReadDat()实现从文件IN.DAT中读取一篇英文文章存入到字符串数组xx中,请编制函数SortCharD(),其 函数的功能是: 以行为单位对字符按从大到小的顺序进行排序,排序后的结果仍按行重新存入字符串数组xx 中,最后调用函数writeDat()把结果xx输出到文件OUT2.DAT中。 例: 原文: dAe,BfC. CCbbAA 结果: fedCBA. bbCCAA 原始数据文件存放的格式是: 每行的宽度均小于80个字符,含标点符号和空格。 部分源程序存在文件prog1.c中。 请勿改动主函数main()、读数据函数ReadDat()和输出数据函数writeDat()的内容。 #include #include #include charxx[50][80]; intmaxline=0;/*文章的总行数*/ intReadDat(void); voidWriteDat(void); voidSortCharD(void) {inti,j,k,strl; charch; for(i=0;i {strl=strlen(xx[i]); for(j=0;j for(k=j+1;k if(xx[i][j] {ch=xx[i][j];xx[i][j]=xx[i][k];xx[i][k]=ch;} } } voidmain() {clrscr(); if(ReadDat()){printf("数据文件IN.DAT不能打开! \n\007"); return; } SortCharD(); WriteDat(); } intReadDat(void) {FILE*fp; inti=0; char*p; if
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 三级 数据库 上机