1、三级网络技术份上机题库11.在文件in.dat中有200组数据,每组有3个数,每个数均是三位数。函数ReadDat()读取这200组数据存放到结构数组aa中,请编制函数jsSort(),其函数的功能是:要求在200组数据中找出条件为每组中的第一个数大于第二个数加第三个数的和,其中满足条件的组数作为函数jsSort()的返回值,同时把满足条件的数据存入结构数组bb中,再对bb中的数据按照每组数据的第一个数加第三个之和的大小进行升序排列(第一个数加第三个数的和均不相等),排序后的结果仍重新存入结构数组bb中,最后调用函数writeDat()把结果bb输出到文件out.dat中。 部分源程序存在文件
2、prog1.c中。请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。#include #include #include typedef struct int x1,x2,x3;data;data aa200,bb200;int jsSort() int i,j,cnt=0; data xy; for(i=0;i(aai.x2+aai.x3) bbcnt+=aai; for(i=0;icnt-1;i+) for(j=i+1;jbbj.x1+bbj.x3) xy=bbi; bbi=bbj; bbj=xy; return cnt;void main(
3、) int count; readDat(); count=jsSort(); /*返回满足条件的个数*/ writeDat(count);readDat() FILE *in; int i; in=fopen(in.dat,r); for(i=0; i200; i+) fscanf(in,%d %d %d,&aai.x1,&aai.x2,&aai.x3); fclose(in); writeDat(int count) FILE *out; int i; clrscr(); out=fopen(out.dat,w); for(i=0; icount; i+) printf(%d,%d,%d
4、第一个数+第三个数=%dn,bbi.x1,bbi.x2,bbi.x3,bbi.x1+bbi.x3); fprintf(out,%d %d %dn,bbi.x1,bbi.x2,bbi.x3); fclose(out);*2. 请编制函数ReadDat()实现从文件IN.DAT中读取1000个十进制整数到数组xx中;请编制函数Compute()分别计算出xx中奇数的个数odd,奇数的平均值ave1,偶数的平均值ave2以及所有奇数的方差totfc的值,最后调用函数WriteDat()把结果输出到OUT.DAT文件中。 计算方差的公式如下: N-1 2 totfc=1/N (xxi-ave1) i=
5、0 设N为奇数的个数,xxi为奇数,ave1为奇数的平均值。 原始数据文件存放的格式是:每行存放10个数,并用逗号隔开。(每个数均大于0且小于等于2000) 部分源程序存在文件prog1.c中。 请勿改动主函数main()和输出数据函数writeDat()的内容。#include #include #include #define MAX 1000int xxMAX,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(
6、IN.DAT,r)=NULL) return 1;/*编制函数ReadDat()的部分*/for(i=0;iMAX;i+) fscanf(fp,%d,&xxi); if(i+1)%10=0) fscanf(fp,n); /*/ fclose(fp); return 0;void Compute(void) int i,yyMAX; for(i=0;iMAX;i+) yyi=0; for(i=0;iMAX;i+) if(xxi%2) yyodd+=xxi; ave1+=xxi; else even+; ave2+=xxi; if(odd=0) ave1=0; else ave1/=odd; if
7、(even=0) ave2=0; else ave2/=even; for(i=0;iodd;i+) totfc+=(yyi-ave1)*(yyi-ave1)/odd;void main() int i; for(i=0;iMAX;i+)xxi=0; if(ReadDat() printf(数据文件IN.DAT不能打开!007n); return; Compute(); printf(ODD=%dnAVE1=%fnAVE2=%fnTOTFC=%fn,odd,ave1,ave2,totfc); WriteDat();void WriteDat(void) FILE *fp; int i; fp=
8、fopen(OUT.DAT,w); fprintf(fp,%dn%fn%fn%fn,odd,ave1,ave2,totfc); fclose(fp);*3. 请编制函数ReadDat()实现从文件IN.DAT中读取1000个十进制整数到数组xx中;请编制函数Compute()分别计算出xx中偶数的个数even,奇数的平均值ave1,偶数的平均值ave2以及方差totfc的值,最后调用函数WriteDat()把结果输出到OUT.DAT文件中。 计算方差的公式如下: N-1 2 totfc=1/N(xxi-ave2) i=0 设N为偶数的个数,xxi为偶数,ave2为偶数的平均值。 原始数据文件存
9、放的格式是:每行存放10个数,并用逗号隔开。(每个数均大于0且小于等于2000) 部分源程序存在文件prog1.c中。 请勿改动主函数main()和输出数据函数writeDat()的内容。#include #include #include #define MAX 1000int xxMAX,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(
10、)的部分*/for(i=0;iMAX;i+) fscanf(fp,%d,&xxi); if(i+1)%10=0) fscanf(fp,n); /*/ fclose(fp); return 0;void Compute(void) int i,yyMAX; for(i=0;iMAX;i+) yyi=0; for(i=0;iMAX;i+) if(xxi%2=0) yyeven+=xxi; ave2+=xxi; else odd+; ave1+=xxi; if(odd=0) ave1=0; else ave1/=odd; if(even=0) ave2=0; else ave2/=even; for
11、(i=0;ieven;i+) totfc+=(yyi-ave2)*(yyi-ave2)/even;void main() int i; for(i=0;iMAX;i+)xxi=0; if(ReadDat() printf(数据文件IN.DAT不能打开!007n); return; Compute(); printf(OVEN=%dnAVE1=%fnAVER2=%fnTOTFC=%fn,even,ave1,ave2,totfc); WriteDat();void WriteDat(void) FILE *fp; int i; fp=fopen(OUT.DAT,w); fprintf(fp,%dn
12、%fn%fn%fn,even,ave1,ave2,totfc); fclose(fp);4. 函数ReadDat()实现从文件ENG.IN中读取一篇英文文章,存入到字符串数组xx中;请编制函数encryptChar(),按给定的替代关系对数组xx中的所有字符进行替代,仍存入数组xx的对应的位置上,最后调用函数WriteDat()把结果xx输出到文件PS5.DAT中。替代关系:f(p)=p*11mod 256 (p是数组中某一个字符的ASCII值,f(p)是计算后新字符的ASCII值),如果原字符是小写字母或计算后f(p)值小于等于32,则该字符不变,否则将f(p)所对应的字符进行替代。部分源程
13、序存在文件prog1.c中。原始数据文件存放的格式是:每行的宽度均小于80个字符。请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。#include #include #include #include unsigned char xx5080;int maxline=0;/*文章的总行数*/int ReadDat(void);void WriteDat(void);void encryptChar() int i,j; for(i=0;imaxline;i+) for(j=0;jstrlen(xxi);j+) if(xxij*11%256=a&
14、xxij=z) continue; else xxij=xxij*11%256;void main() clrscr(); if(ReadDat() printf(数据文件ENG.IN不能打开!n007); return; encryptChar(); WriteDat();int ReadDat(void) FILE *fp; int i=0; unsigned char *p; if(fp=fopen(eng.in,r)=NULL) return 1; while(fgets(xxi,80,fp)!=NULL) p=strchr(xxi,n); if(p)*p=0; i+;maxline=
15、i;fclose(fp);return 0;void WriteDat(void) FILE *fp; int i; fp=fopen(ps5.dat,w); for(i=0;imaxline;i+) printf(%sn,xxi); fprintf(fp,%sn,xxi); fclose(fp);*5. 程序prog1.c的功能是:把 s 字符串中的所有字符左移一个位置,串中的第一个字符移到最后。请考生编写函数chg(char *s)实现程序要求,最后调用函数readwriteDAT( )把结果输出到bc2.out文件中。 例如:s字符串中原有内容为:Mn.123xyZ,则调用该函数后,结果
16、为:n.123xyZM。 注意:部分源程序存在文件prog1.c文件中。 请勿改动主函数main( )和输出数据函数readwriteDAT()的内容。#include #include #define N 81void readwriteDAT();void chg(char *s) int i; char ch=*s; for(i=0;istrlen(s)-1;i+) si=si+1; sstrlen(s)-1=ch;main() char a N ; clrscr(); printf(Enter a string : ); gets(a); printf(The original str
17、ing is : ); puts(a); chg(a); printf(The string after modified : ); puts(a); readwriteDAT();void readwriteDAT() int i ; char aN ; FILE *rf, *wf ; rf = fopen(bc2.in, r) ; wf = fopen(bc2.out, w) ; for(i = 0 ; i 50 ; i+) fscanf(rf, %s, a) ; chg(a) ; fprintf(wf, %sn, a) ; fclose(rf) ; fclose(wf) ;*6.程序PR
18、OG1.C的功能是:将大于整数m且紧靠m的k个素数存入数组xx。请编写一个函数num(int m,int k,int xx)实现程序的要求。 最后调用函数readwriteDat()把结果输出到文件out.dat中。 例如:若输入17 5 则应输出:19,23,29,31,37。 请勿改动主函数main()和写函数PROG1.C的内容。#include #include void readwriteDat();int isP(int m) int i; for(i=2;i0;m+) if(isP(m) xxs+=m; k-;main() int m,n,xx1000; clrscr(); pr
19、intf(nPlease enter two integers:); scanf(%d%d,&m,&n); num(m,n,xx); for(m=0;mn;m+) printf(%d ,xxm); printf(n); readwriteDat();void readwriteDat() int m,n,xx1000, i; FILE *rf,*wf; rf=fopen(in.dat,r); wf=fopen(out.dat,w); for(i=0;i10;i+) fscanf(rf,%d %d,&m,&n); num(m,n,xx); for(m=0;mn;m+)fprintf(wf,%d
20、,xxm); fprintf(wf,n); fclose(rf); fclose(wf);7. 下列程序的功能是:寻找并输出11至999之间的数m,它满足m,m2和m3均为回文数。所谓回文数是指其各位数字左右对称的整数,例如121,676,94249等。满足上述条件的数如m=11,m2=121,m3=1331皆为回文数。请编制函数int svalue(long m)实现此功能,如果是回文数,则函数返回1,反之则返回0。最后把结果输出到文件out.dat中。 注意:部分源程序已给出。 请勿改动主函数main()的内容。#include int jsValue(long n)int i,strl,
21、half; char xy20; ltoa(n,xy,10); /*注意这里不能使用itoa()函数,因为n是long 型的*/ strl=strlen(xy); half=strl/2; for(i=0;i=half) return 1; else return 0;main()long m; FILE *out; out=fopen(out.dat,w); for(m=11;m1000;m+) if(jsValue(m)&jsValue(m*m)&jsValue(m*m*m) printf(m=%4ld,m*m=%6ld,m*m*m=%8ld n,m,m*m,m*m*m); fprintf
22、(out,m=%4ld,m*m=%6ld,m*m*m=%8ld n,m,m*m,m*m*m); fclose(out);8. 函数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
23、)所对应的字符进行替代。部分源程序存在文件prog1.c中。原始数据文件存放的格式是:每行的宽度均小于80个字符。请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。#include #include #include #include unsigned char xx5080;int maxline=0;/*文章的总行数*/int ReadDat(void);void WriteDat(void);void encryptChar() int i,j; for(i=0;imaxline;i+) for(j=0;jstrlen(xxi);j+) i
24、f(xxij*11%256=A&xxij=Z) continue; else xxij=xxij*11%256;void main() clrscr(); if(ReadDat() printf(数据文件ENG.IN不能打开!n007); return; encryptChar(); WriteDat();int ReadDat(void) FILE *fp; int i=0; unsigned char *p; if(fp=fopen(eng.in,r)=NULL) return 1; while(fgets(xxi,80,fp)!=NULL) p=strchr(xxi,n); if(p)*
25、p=0; i+;maxline=i;fclose(fp);return 0;void WriteDat(void) FILE *fp; int i; fp=fopen(ps7.dat,w); for(i=0;imaxline;i+) printf(%sn,xxi); fprintf(fp,%sn,xxi); fclose(fp);*9.将文件IN.DAT中读取200个整数至数组xx中,求出最大数max及最大数的个数cnt和数组xx中能被3整除或能被7整除的算术平均值pj(保留2位小数)。 结果max,cnt,pj输出到OUT.DAT中。 部分程序、读数据函数read_dat(int xx200)及输出格式已给出。#include #include #define N 200void read_dat(int xxN) int i,j; FILE *fp; fp=fopen(in.dat,r)
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1