全国计算机等级考试
三级C语言上机100题
2005年9月最新修订版
由木易修订发布于https://www.doczj.com/doc/4512049132.html,
欣宇重排版上传于啄木论坛https://www.doczj.com/doc/4512049132.html, 几点说明:
1、题目标题号前用“☆”显示的是2005年4月份本人根据各大论坛考生反聩的题号集中而来,题号前加“★”为2005年9月上机考试题,其中难免有题型相同而题号增加的现象,此类标明,仅供参考。
2、每种题目,只用一种解题方法,蓝色加粗部分为解题答案,此种方法本人觉得容易理解,不易出错,适合初学者。
3、特别说明:所有解法,本人均上机验证通过。
4、个别南开题如57、100题,题目与原书有所不同,是按实际考试的题目所来,并对今年在实际上机中出现的考题,用红色部分表示实际上机题中注明事项。**********************************☆题目1
请编写一个函数jsValue(int m,int k,int
xx[]),该函数的功能是:将大于整数m 且紧靠m的k个素数存入数组xx传回。
最后调用函数writeDat()读取10组数据,分别得出结果且把结果输出到文件out.dat中。
部分源程序存在文件prog1.c中。
例如:若输入17 5 则应输出:19,23,29,31,37。
请勿改动主函数main()和写函数writeDat()的内容。
#include
#include
void readwriteDat();
int isP(int m)
{
int i;
for(i=2;i if(m % i==0)return 0; return 1; } void num(int m,int k,int xx[]) { int s=0; for(m=m+1;k>0;m++) if(isP(m)) { xx[s++]=m; k--;} } main() { int m,n,xx[1000]; clrscr(); printf("\nPlease enter two integers:"); scanf("%d%d",&m,&n); num(m,n,xx); for(m=0;m printf("%d ",xx[m]); printf("\n"); readwriteDat(); } void readwriteDat() { int m,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 ",xx[m]); fprintf(wf,"\n"); } fclose(rf); fclose(wf); } ********************************* ☆题目2 已知数据文件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.DA T中的任 何数据、主函数main()、读函数readDat()和写函数writeDat()的内容。 #include #define MAX 200 int a[MAX], b[MAX], cnt = 0 ; void jsVal() { int i,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] } void readDat() { int i ; FILE *fp ; fp = fopen("in.dat", "r") ; for(i = 0 ; i < MAX ; i++) fscanf(fp, "%d", &a[i]) ; fclose(fp) ; } void main() { int i ; readDat() ; jsVal() ; printf("满足条件的数=%d\n", cnt) ; for(i = 0 ; i < cnt ; i++) printf("%d ", b[i]) ; printf("\n") ; writeDat() ; } writeDat() { FILE *fp ; int i ; fp = fopen("out.dat", "w") ; fprintf(fp, "%d\n", cnt) ; for(i = 0 ; i < cnt ; i++) fprintf(fp, "%d\n", b[i]) ; fclose(fp) ; } *********************************★题目3 函数ReadDat( )实现从文件IN.DAT中读取一篇英文文章存入到字符串数组xx 中;请编制函数StrOR( ),其函数的功能是:以行为单位依次把字符串中所有小写字母o左边的字符串内容移到该串的右边存放,然后把小写字母o删除,余下的字符串内容移到已处理字符串的左边存放,之后把已处理的字符串仍按行重新存入字符串数组xx中。最后main()函数调用函数WriteDat()把结果xx输出到文件OUT5.DA T中。 原始数据文件存放的格式是:每行的宽度均小于80个字符,含标点符号和空格。 注意:部分源程序存放在文件prog1.c中。 请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。 #include #include #include char xx[50][80] ; int maxline = 0 ; /* 文章的总行数*/ int ReadDat(void) ; void WriteDat(void) ; void StrOR(void) {int i,righto,j,s,k; char tem[80]; for(i=0;i for(j=strlen(xx[i])-1;j>=0;j--) { k=0; memset(tem,0,80); if(xx[i][j]=='o') {righto=j; for(s=righto+1;s 按行重新存入字符串数组xx 中,最后调用函数writeDat()把结果xx 输出到文件OUT6.DA T 中。 例如:原文:You He Me I am a student. 结果:Me He You student a am I 原始数据文件存放的格式是:每行的宽度均小于80个字符,含标点符号和 空格。 部分源程序存在文件prog1.c 中。 请勿改动主函数main()、读数据函数ReadDat()和输出数据函数writeDat()的内容。 #include while(fgets(xx[i],80,fp)!=NULL){ p=strchr(xx[i],'\n'); if(p)*p=0; i++; } maxline=i; fclose(fp); return 0; } void WriteDat(void) { FILE *fp; int i; clrscr(); fp=fopen("OUT6.DAT","w"); for(i=0;i fclose(fp); } ********************************** ☆题目5(整数排序题) 在文件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()的内容。 #include int aa[200],bb[10]; 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] void main() { readDat(); jsSort(); writeDat(); } readDat() { FILE *in; int i; in=fopen("in.dat","r"); for(i=0; i<200; i++) fscanf(in,"%d,",&aa[i]); fclose(in); } writeDat() { FILE *out; int i; clrscr(); out=fopen("out.dat","w"); for(i=0; i<10; i++){ printf(" %d",bb[i]); fprintf(out,"%d\n",bb[i]); } fclose(out); } ********************************* ☆题目6正整数排序 在文件in.dat中有200个正整数,且每个数均在1000至9999之间。函数ReadDat()读取这200个数存放到数组aa中。请编制函数jsSort(),其函数的功能是:要求按每个数的后三位的大小进行降序排列,然后取出满足此条件的前10个数依次存入数组b中,如果后三位的数值相等,则按原先的数值进行升序排列。最后调用函数WriteDat()把结果bb输出到文件out.dat中。 例:处理前9012 5099 6012 7025 8088 处理后5099 8088 7025 6012 9012 注意:部分源程序已给出。 请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。 #include #include #include int aa[200],bb[10]; void jsSort() { int i,j,data; for(i=0;i<199;i++) for(j=i+1;j<200;j++) if(aa[i]%1000 {data=aa[i];aa[i]=aa[j];aa[j]=data;} for(i=0;i<10;i++) bb[i]=aa[i]; } void main() { readDat(); jsSort(); writeDat(); system("pause"); } readDat() { FILE *in; int i; in=fopen("in.dat","r"); for(i=0; i<200; i++) fscanf(in,"%d,",&aa[i]); fclose(in); } writeDat() { FILE *out; int i; clrscr(); out=fopen("out.dat","w"); for(i=0; i<10; i++){ printf("i=%d,%d\n",i+1,bb[i]); fprintf(out,"%d\n",bb[i]); } fclose(out); } ****************************** ☆题目7(结构体操作题) 已知在文件IN.DAT中存有100个产品销 售记录,每个产品销售记录由产品代码 dm(字符型4位),产品名称mc(字符型 10位),单价dj(整型),数量sl(整型),金 额je(长整型)五部分组成。其中:金额= 单价*数量计算得出。函数ReadDat()是读 取这100个销售记录并存入结构数组sell 中。请编制函数SortDat(),其功能要求: 按产品代码从大到小进行排列,若产品 代码相同,则按金额从大到小进行排列, 最终排列结果仍存入结构数组sell中,最 后调用函数WriteDat()把结果输出到文件 OUT6.DA T中。 部分源程序存在文件prog1.c中。 请勿改动主函数main()、读数据函数 ReadDat()和输出数据函数WriteDat()的 内容。 #include #include #include #include #include #define MAX 100 typedef struct{ char dm[5]; /*产品代码*/ char mc[11]; /*产品名称*/ int dj; /*单价*/ int sl; /*数量*/ long je; /*金额*/ }PRO; PRO sell[MAX]; void ReadDat(); void WriteDat(); 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 l[j].je) {xy=sell[i]; sell [i]=sell[j]; sell[j]=xy;} } void main() { memset(sell,0,sizeof(sell)); ReadDat(); SortDat(); WriteDat(); } void ReadDat() { FILE *fp; char str[80],ch[11]; int i; fp=fopen("IN.DA T","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); } void WriteDat(void) { FILE *fp; int i; 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(字符替换题) 函数ReadDat()实现从文件ENG.IN中读取一篇英文文章,存入到字符串数组xx 中;请编制函数encryptChar(),按给定的替代关系对数组xx中的所有字符进行替代,仍存入数组xx的对应的位置上,最后调用函数WriteDat()把结果xx输出到文件PS1.DA T中。 替代关系:f(p)=p*11 mod 256(p是数组中某一个字符的ASCII值,f(p)是计算后新字符的ASCII值),如果计算后f(p)值小于等于32或大于130,则该字符不变,否则将f(p)所对应的字符进行替代。(注意中间变量用无符号整型),部分源程序存在文件prog1.c中。原始数据文件存放的格式是:每行的宽度均小于80个字符。 请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。 #include #include #include #include unsigned char xx[50][80]; int maxline=0;/*文章的总行数*/ int ReadDat(void); void WriteDat(void); void encryptChar() { int i,j; for(i=0;i for(j=0;j if(xx[i][j]*11%256<=32||xx[i][j]*11%256 >130) continue; else xx[i][j]=xx[i][j]*11%256; } void main() { clrscr(); if(ReadDat()){ printf("数据文件ENG.IN不能打开!\n\007"); 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(xx[i],80,fp)!=NULL){ p=strchr(xx[i],'\n'); if(p)*p=0; i++; } maxline=i; fclose(fp); return 0; } void WriteDat(void) { FILE *fp; int i; fp=fopen("ps1.dat","w"); for(i=0;i printf("%s\n",xx[i]); fprintf(fp,"%s\n",xx[i]); } fclose(fp); } ********************************* ★☆题目9(字符串排序题) 函数ReadDat()实现从文件IN.DA T中读 取一篇英文文章存入到字符串数组xx 中,请编制函数SortCharD(),其函数的 功能是:以行为单位对字符按从大到小 的顺序进行排序,排序后的结果仍按行 重新存入字符串数组xx中,最后调用函 数writeDat()把结果xx输出到文件 OUT2.DA T中。 例:原文:dAe,BfC. CCbbAA 结果:fedCBA. bbCCAA 原始数据文件存放的格式是:每行 的宽度均小于80个字符,含标点符号和 空格。 部分源程序存在文件prog1.c中。 请勿改动主函数main()、读数据函数 ReadDat()和输出数据函数writeDat()的内 容。 #include #include #include char xx[50][80]; int maxline=0;/*文章的总行数*/ int ReadDat(void); void WriteDat(void); void SortCharD(void) {int i,j,k,strl; char ch; 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;} } } void main() { clrscr(); if(ReadDat()){ printf("数据文件IN.DAT不能打开! \n\007"); return; } SortCharD(); WriteDat(); } int ReadDat(void) { FILE *fp; int i=0; char *p; if((fp=fopen("IN.DAT","r"))==NULL) return 1; while(fgets(xx[i],80,fp)!=NULL){ p=strchr(xx[i],'\n'); if(p)*p=0; i++; } maxline=i; fclose(fp); return 0; } void WriteDat(void) { FILE *fp; int i; fp=fopen("OUT2.DAT","w"); for(i=0;i printf("%s\n",xx[i]); fprintf(fp,"%s\n",xx[i]); } fclose(fp); } ******************************** ★☆题目10(替换字符题) 函数ReadDat()实现从文件IN.DA T中读 取一篇英文文章存入到字符串数组xx 中,请编制函数ConvertCharA(),其函 数的功能是:以行为单位把字符串中的 所有小写字母改写成该字母的下一个字 母,如果是字母z,则改写成字母a。大 写字母仍为大写字母,小写字母仍为小 写字母,其他字符不变。把已处理的字 符串仍按行重新存入字符串数组xx中, 最后调用函数writeDat()把结果xx输出 到文件OUT1.DA T中。 例:原文:Adb.Bcdza abck.LLhj 结果:Aec.Bdeab bcdl.LLik 原始数据文件存放的格式是:每行 的宽度均小于80个字符,含标点符号和 空格。 部分源程序存在文件prog1.c中。 请勿改动主函数main()、读数据函数 ReadDat()和输出数据函数writeDat()的内 容。 #include #include #include char xx[50][80]; int maxline=0;/*文章的总行数*/ int ReadDat(void); void WriteDat(void); void ConvertCharA(void) { int i,j; for(i=0;i { for(j=0;j if(xx[i][j]=='z') xx[i][j]='a'; else if(xx[i][j]>='a'&&xx[i][j]<='y') xx[i][j]+=1; } } void main() { clrscr(); if(ReadDat()){ printf("数据文件IN.DAT不能打开!\n\007"); return; } ConvertCharA(); WriteDat(); } int ReadDat(void) { FILE *fp; int i=0; char *p; if((fp=fopen("IN.DA T","r"))==NULL) return 1; while(fgets(xx[i],80,fp)!=NULL){ p=strchr(xx[i],'\n'); if(p)*p=0; i++; } maxline=i; fclose(fp); return 0; } void WriteDat(void) { FILE *fp; int i; clrscr(); fp=fopen("OUT1.DAT","w"); for(i=0;i printf("%s\n",xx[i]); fprintf(fp,"%s\n",xx[i]); } fclose(fp); } ********************************** ☆题目11(字符串字母移位题) 程序prog1.c的功能是:把s 字符串中的所有字母改写成该字母的下一个字母,字母z改写成字母a。要求大写字母仍为 大写字母,小写字母仍为小写字母,其 它字符不做改变。 请考生编写函数chg(char *s)实现 程序要求,最后调用函数readwriteDAT( ) 把结果输出到文件bc1.out中。 例如:s 字符串中原有的内容为: Mn.123Zxy,则调用该函数后,结果为: No.123Ayz。 注意:部分源程序存在文件prog1.c 文件中。 请勿改动主函数main( )和输出数据 函数readwriteDAT()的内容。 #include #include #include #include #define N 81 void readwriteDAT(); void chg(char *s) {int I; for(I=0;I if(s[i]=='z'||s[i]=='Z') s[i]-=25; else if(s[i]>='a'&&s[i]<='y'||s[i] >='A'&&s[i] <='Y') s[i]+=1; } main( ) { char a[N]; clrscr(); printf("Enter a string : "); gets(a); printf("The original string is : "); puts(a); chg(a); printf("The string after modified : "); puts (a); readwriteDAT() ; } void readwriteDAT() { int i ; char a[N] ; FILE *rf, *wf ; rf = fopen("bc1.in", "r") ; wf = fopen("bc1.out", "w") ; for(i = 0 ; i < 50 ; i++) { fscanf(rf, "%s", a) ; chg(a) ; fprintf(wf, "%s\n", a) ; } fclose(rf) ; fclose(wf) ; } ******************************** ★☆题目12(结构体运算题题) 已知在文件IN.DAT中存有100个产品销 售记录,每个产品销售记录由产品代码 dm(字符型4位),产品名称mc(字符型 10位),单价dj(整型),数量sl(整型),金 额je(长整型)五部分组成。其中:金额= 单价*数量计算得出。函数ReadDat()是读 取这100个销售记录并存入结构数组sell 中。请编制函数SortDat(),其功能要求: 按产品名称从小到大进行排列,若产品 名称相等,则按金额从小到大进行排列, 最终排列结果仍存入结构数组sell中,最 后调用函数WriteDat()把结果输出到文件 OUT5.DAT中。 部分源程序存在文件prog1.c中。 请勿改动主函数main()、读数据函数 ReadDat()和输出数据函数WriteDat()的 内容。 #include #include #include #include #include #define MAX 100 typedef struct{ char dm[5]; /*产品代码*/ char mc[11]; /*产品名称*/ int dj; /*单价*/ int sl; /*数量*/ long je; /*金额*/ }PRO; PRO sell[MAX]; void ReadDat(); void WriteDat(); 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;} } void main() { memset(sell,0,sizeof(sell)); ReadDat(); SortDat(); WriteDat(); } void ReadDat() { FILE *fp; char str[80],ch[11]; int i; 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); } void WriteDat() { FILE *fp; int i; fp=fopen("OUT5.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); } ***************************** 题目13(结构体运算题) 已知在文件IN.DA T中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位),产品名称mc(字符型10位),单价dj(整型),数量sl(整型),金额je(长整型)五部分组成。其中:金额=单价*数量计算得出。函数ReadDat()是读取这100个销售记录并存入结构数组sell 中。请编制函数SortDat(),其功能 要求:按产品代码从小到大进行排列,若产品代码相等,则按金额从大到小进行排列,最终排列结果仍存入结构数组sell中,最后调用函数WriteDat()把结果输出到文件OUT9.DA T中。 部分源程序存在文件prog1.c中。 请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。 #include #include #include #include #include #define MAX 100 typedef struct{ char dm[5]; /*产品代码*/ char mc[11]; /*产品名称*/ int dj; /*单价*/ int sl; /*数量*/ long je; /*金额*/ }PRO; PRO sell[MAX]; void ReadDat(); void WriteDat(); 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 {xy=sell[i];sell[i]=sell[j];sell[j]=xy;} } void main() { memset(sell,0,sizeof(sell)); ReadDat(); SortDat(); WriteDat(); } void ReadDat() { FILE *fp; char str[80],ch[11]; int i; 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); } void WriteDat() { FILE *fp; int i; fp=fopen("OUT9.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); } ***************************** ★☆题目14(整数统计排序题) 已知数据文件IN.DAT中存有200个四位 数,并已调用读函数readDat()把这些数 存入数组a中,请考生编制一函数 jsVal(),其功能是:依次从数组a中取出 一个四位数,如果该四位数连续大于该 四位数以后的五个数且该数是奇数(该 四位数以后不满五个数,则不统计),则 统计出满足此条件的个数cnt并把这些四 位数按从小到大的顺序存入数组b中, 最后调用写函数writeDat( )把结果cnt以 及数组b中符合条件的四位数输出到 OUT.DA T文件中。 注意:部分源程序存在文件prog1.c 中。 程序中已定义数组:a[200],b[200], 已定义变量:cnt 请勿改动数据文件IN.DA T中的任 何数据、主函数main()、读函数readDat() 和写函数writeDat()的内容。 #include #define MAX 200 int a[MAX], b[MAX], cnt = 0 ; void jsVal() {int i,j,flag; for(i=0;i {for(j=i+1;j<=i+5;j++) if(a[i]>a[j]&&a[i]%2) flag=1; else {flag=0;break;} if(flag==1) b[cnt++]=a[i]; } for(i=0;i for(j=i+1;j if(b[i]>b[j]) {flag=b[i];b[i]=b[j];b[j]=flag;} } void readDat() { int i ; FILE *fp ; fp = fopen("in.dat", "r") ; for(i = 0 ; i < MAX ; i++) fscanf(fp, "%d", &a[i]) ; fclose(fp) ; } void main() { int i ; readDat() ; jsVal() ; printf("满足条件的数=%d\n", cnt) ; for(i = 0 ; i < cnt ; i++) printf("%d ", b[i]) ; printf("\n") ; writeDat() ; } writeDat() { FILE *fp ; int i ; fp = fopen("out.dat", "w") ; fprintf(fp, "%d\n", cnt) ; for(i = 0 ; i < cnt ; i++) fprintf(fp, "%d\n", b[i]) ; fclose(fp) ; } ************************ ★题目15(整数各位数字运算排序题) 已知数据文件IN.DAT中存有200个四位 数,并已调用读函数readDat()把这些数 存入数组a中,请考生编制一函数 jsVal(),其功能是:若一个四位数的千位 数字上的值小于等于百位数字上的值, 百位数字上的值小于等于十位数字上的 值,以及十位数字上的值小于等于个位 数字上的值,并且原四位数是偶数,则 统计出满足此条件的个数cnt 并把这些四位数按从小到大的顺序存入数组b 中,最后调用写函数writeDat()把结果cnt 以及数组b 中符合条件的四位数输出到OUT.DA T 文件中。 注意:部分源程序存在文件prog1.c 中。 程序中已定义数组:a[200],b[200],已定义变量:cnt 请勿改动数据文件IN.DAT 中的任何数据、主函数main()、读函数readDat()和写函数writeDat()的内容。 #include 函数ReadDat()实现从文件IN.DA T 中读取一篇英文文章存入到字符串数组xx 中,请编制函数StrCharJR(),其函数的功能是:以行为单位把字符串中所有字符的ASCII 值右移4位,然后把右移后的字符ASCII 值再加上原字符的ASCII 值,得到新的字符仍存入原字符串对应的位置上。最后把已处理的字符串仍按行重新存入字符串数组xx 中,最后调用函数writeDat()把结果xx 输出到文件OUT8.DA T 中。 原始数据文件存放的格式是:每行的宽度均小于80个字符,含标点符号和空格。 部分源程序存在文件prog1.c 中。 请勿改动主函数main()、读数据函数ReadDat()和输出数据函数writeDat()的内容。 #include char xx[50][80]; int maxline=0;/*文章的总行数*/ int ReadDat(void); void WriteDat(void); void StrCharJR() {int i,j; for(i=0;i void WriteDat(void) { FILE *fp; int i; clrscr(); fp=fopen("OUT8.DAT","w"); for(i=0;i fclose(fp); } ************************* ☆题目17 (亲朋字符替换题) 函数READDA T ()实现从文件IN.DAT 中读取一篇英文文章存入到字符串数组XX 中;请编制函数CHA(),其函数功能是:以行为单位把字符串中的第一个字符的ASCII 值加第二个字符的ASCII 值,得到第一个亲朋字符,第二个字符的ASCII 值加第三个字符的ASCII 值,得到第二个新字符,依此类推一直处理到最后第二个字符,最后一个字符的ASCII 值加原第一个字符的ASCII 值,得到最后一个新的字符,得到的新字符分别存放在原字符串对应的位置上。最后把已处理的字符串逆转后按行重新存入字符串数组XX 中,最后调用函数WRITEDAT()把结果XX 输出到文件OUT9.DAT 中.原始数据文件存放的格式是:每行的宽度均小于80个字符,含标点符号和空格. 注意:部分源程序已给出。 请勿改动主函数main()、读数据函数ReadDat()和输出数据函数writeDat()的内容。 #include char xx[50][80] ; int maxline = 0 ; /* 文章的总行数 */ int ReadDat(void) ; void WriteDat(void) ; void ChA(void) { int i,j; char ch; for(i=0;i for(j=0;j void main() { clrscr() ; if(ReadDat()) { printf("数据文件IN.DA T 不能打开!\n\007") ; return ; } ChA() ; WriteDat() ; } int ReadDat(void) { FILE *fp ; int i = 0 ; char *p ; if((fp = fopen("IN.DAT", "r")) == NULL) return 1 ; while(fgets(xx[i], 80, fp) != NULL) { p = strchr(xx[i], '\n') ; if(p) *p = 0 ; i++ ; } maxline = i ; fclose(fp) ; return 0 ; } void WriteDat(void) { FILE *fp ; int i ; clrscr() ; fp = fopen("OUT9.DA T", "w") ; for(i = 0 ; i < maxline ; i++) { printf("%s\n", xx[i]) ; fprintf(fp, "%s\n", xx[i]) ; } fclose(fp) ; } ********************************* ☆题目18 函数ReadDat()实现从文件ENG.IN中读取一篇英文文章,存入到字符串数组xx 中;请编制函数encryptChar(),按给定的替代关系对数组xx中的所有字符进行替代,仍存入数组xx的对应的位置上,最后调用函数WriteDat()把结果xx输出到文件PS10.DAT中。 替代关系:f(p)=p*11 mod 256(p是数组中某一个字符的ASCII值,f(p)是计算后新字符的ASCII值),如果原字符的ASCII值是偶数或计算后f(p)值小于等于32,则该字符不变,否则将f(p)所对应的字符进行替代。 部分源程序存在文件prog1.c中。原始数据文件存放的格式是:每行的宽度均小于80个字符。 请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。 #include #include #include #include unsigned char xx[50][80]; int maxline=0;/*文章的总行数*/ int ReadDat(void); void WriteDat(void); void encryptChar() { int i,j; for(i=0;i for(j=0;j if(xx[i][j]*11%256<=32||xx[i][j]%2==0) continue; else xx[i][j]=xx[i][j]*11%256; } void main() { clrscr(); if(ReadDat()){ printf("数据文件ENG.IN不能打开! \n\007"); 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(xx[i],80,fp)!=NULL){ p=strchr(xx[i],'\n'); if(p)*p=0; i++; } maxline=i; fclose(fp); return 0; } void WriteDat(void) { FILE *fp; int i; fp=fopen("ps10.dat","w"); for(i=0;i printf("%s\n",xx[i]); fprintf(fp,"%s\n",xx[i]); } fclose(fp); } ********************************* ☆题目19(单词个数统计题) 编写一个函数findStr(char *str,char *substr),该函数统计一个长度为2的子 字符串在另一个字符串中出现的次数。 例如,假定输入的字符串为"asd asasdfg asd as zx67 asd mklo",子字符串为"as", 函数返回值是6。 函数ReadWrite()实现从文件in.dat 中读取两个字符串,并调用函数 findStr(),最后把结果输出到文件out.dat 中。 注意:部分源程序存在文件prog1.c 中。 请勿改动主函数main()和其它函数 中的任何内容,仅在函数findStr()的花括 号中填入你编写的若干语句。 #include #include #include int findStr(char *str,char *substr) { int i,j,len1,len2,cnt=0,flag; len1=strlen(str); len2=strlen(substr); for(i=0;i { for(j=0;j if(str[i+j]==substr[j]) flag=1; else {flag=0;break;} if(flag==1) cnt++; } return cnt; } main() { char str[81], substr[3] ; int n ; clrscr() ; printf("输入原字符串:") ; gets(str) ; printf("输入子字符串:") ; gets(substr) ; puts(str) ; puts(substr) ; n=findStr(str, substr) ; printf("n=%d\n", n) ; ReadWrite() ; } ReadWrite() { char str[81], substr[3], ch; int n, len, i = 0; FILE *rf, *wf ; rf = fopen("in.dat", "r") ; wf = fopen("out.dat", "w") ; while(i < 25) { fgets(str, 80, rf) ; fgets(substr, 10, rf) ; len = strlen(substr) - 1 ; ch = substr[len] ; if(ch == '\n' || ch == 0x1a) substr[len] = 0 ; n=findStr(str, substr); fprintf(wf, "%d\n", n) ; i++ ; } fclose(rf) ; fclose(wf) ; } ******************************* ★题目20(Fibonacci数列题) 编写函数jsValue,它的功能是:求 Fibonacci 数列中大于t 的最小的一个数,结果由函数返回。其中Fibonacci 数列F(n)的定义为: F(0)=0,F(1)=1 F(n)=F(n-1)+F(n-2) 最后调用函数writeDat()读取50个数据t ,分别得出结果且把结果输出到文件out.dat 中。 例如:当t=1000时,函数值为:1597。 部分源程序存在文件prog1.c 中。 请勿改动主函数main()和写函数writeDat()的内容。 #include } aver/=N; } void main() { int i ; clrscr() ; for(i = 0 ; i < MAXNUM ; i++) xx[i] = 0 ; if(ReadDat()) { printf("数据文件IN.DAT不能打 开!\007\n") ; return ; } Calvalue() ; printf("文件IN.DAT中共有实数=%d个\n", N) ; printf("平均值=%.2lf\n", aver) ; printf("整数部分之和=%.2lf\n", sumint) ; printf("小数部分之和=%.2lf\n", sumdec) ; WriteDat() ; system("pause"); } int ReadDat(void) { FILE *fp ; int i = 0 ; if((fp = fopen("in.dat", "r")) == NULL) return 1 ; while(!feof(fp)) { fscanf(fp, "%d,", &xx[i++]) ; } fclose(fp) ; return 0 ; } void WriteDat(void) { FILE *fp ; fp = fopen("OUT.DA T", "w") ; fprintf(fp, "%.2lf\n%.2lf\n%.2lf\n", aver,sumint,sumdec) ; fclose(fp) ; } ******************************* 题目24(完全平方数问题) 下列程序prog1.c的功能是:在三位整数(100至999)中寻找符合条件的整数并依次从小到大存入数组中;它既是完全平方数,又是两位数字相同,例如144、676等。 请编制函数实现此功能,满足该条件的整数的个数通过所编制的函数返回。 最后调用函数writeDat()把结果输出到文件out.dat中。 请勿改动主函数main()和写函数writeDat()的内容。 #include int jsValue(int bb[]) {int i,j,k=0; int hun,ten,data; for(i=10;i<32;i++) {j=I*I; hum=j/100; ten=j%100/10; data=j%10; if(hum==ten||hum==data||ten==data) bb[k++]=j;} return k; } main() { int b[20],num; num=jsValue(b); writeDat(num,b); } writeDat(int num,int b[]) { FILE *out; int i; out=fopen("out.dat","w"); printf("%d\n",num); fprintf(out,"%d\n",num); for(i=0;i ntf(out,"%d\n",b[i]);} fclose(out); } *************************** ★题目25 (回文数问题) 下列程序的功能是:寻找并输出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,half; char xy[20]; ltoa(n,xy,10); /*注意这里不能使用itoa() 函数,因为n是long 型的*/ strl=strlen(xy); half=strl/2; for(i=0;i if(xy[i]!=xy[--strl]) break; if(i>=half) return 1; else return 0; } main() {long m; FILE *out; out=fopen("out.dat","w"); for(m=11;m<1000;m++) { if(jsValue(m)&&jsValue(m*m)&&jsValu e(m*m*m)) { printf("m=%4ld,m*m=%6ld,m*m*m=% 8ld \n",m,m*m,m*m*m); fprintf(out,"m=%4ld,m*m=%6ld,m*m*m= %8ld \n",m,m*m,m*m*m); } } fclose(out); system("pause"); } 或者下面的解法: int jsValue(long n) {long int s=0,k; k=n; while(k) { s=s*10+k%10; k/=10; } if(s==n) return 1; if(s!=n) return 0; } 输出结果为: m= 11,m*m= 121,m*m*m= 1331 m= 101,m*m= 10201,m*m*m= 1030301 m= 111,m*m= 12321,m*m*m= 1367631 **************************** ★☆题目26(整数统计运算题) 已知在文件IN.DAT中存有若干个(个数 <200)四位数字的正整数,函数ReadDat() 读取这若干个正整数并存入数组xx中。 请编制函数CalValue(),其功能要求:1、 求出这文件中共有多少个正整数 totNum;2、求这些数右移1位后,产生 的新数是偶数的数的个数totCnt,以及满 足此条件的这些数(右移前的值)的算术 平均值totPjz,最后调用函数writeDat() 把所求的结果输出到文件OUT.DAT中。 部分源程序存在文件prog1.c中。 请勿改动主函数main()、读函数 ReadDat()和写函数writeDat()的内容。 #include #include #define MAXNUM 200 int xx[MAXNUM]; int totNum=0; /*文件IN.DA T中共有多少 个正整数*/ int totCnt=0; /*符合条件的正整数的个数 */ double totPjz=0.0; /*平均值*/ int ReadDat(void); void writeDat(void); void CalValue(void) {int i,data; for(i=0;i if(xx[i]>0) { totNum++; data=xx[i]>>1; if(data%2==0){totCnt++;totPjz+=xx[i];} } if(totCnt==0) totPjz=0; else totPjz/=totCnt; } void main() { int i; clrscr(); for(i=0;i 的个位数字是原四位数的百位数字),如果新组成的两个十位数ab-cd>=0且ab-cd<=10且两个数均是奇数,同时两个新数的十位数字均不为零,则将满足此条件的四位数按从大到小的顺序存入数组b 中,并要计算满足上述条件的四位数的个数cnt 。最后main()函数调用写函数writeDat( )把结果cnt 以及数组b 中符合条件的四位数输出到OUT.DAT 文件中。 注意:部分源程序存在文件prog1.c 中。 程序中已定义数组:a[200],b[200],已定义变量:cnt 请勿改动数据文件IN.DA T 中的任何数据、主函数main()、读函数readDat()和写函数writeDat()的内容。 #include printf("满足条件的数=%d\n", cnt) ; for(i = 0 ; i < cnt ; i++) printf("%d ", b[i]) ; printf("\n") ; writeDat() ; } writeDat() { FILE *fp ; int i ; fp = fopen("out.dat", "w") ; fprintf(fp, "%d\n", cnt) ; for(i = 0 ; i < cnt ; i++) fprintf(fp, "%d\n", b[i]) ; fclose(fp) ; } **************************** ☆题目29(整数各位打散组合运算题) 已知数据文件IN.DAT 中存有200个四位数,并已调用读函数readDat()把这些数存入数组a 中,请考生编制一函数jsVal(),其功能是:把千位数字和十位数字重新组成一个新的十位数ab (新十位数的十位数字是原四位数的千位数字,新十位数的个位数字是原四位数的十位数字),以及把个位数字和百位数字组成另一个新的十位数cd (新十位数的十位数字是原四位数的个位数字,新十位数的个位数字是原四位数的百位数字),如果新组成的两个十位数ab-cd>=10且ab-cd<=20且两个数均是偶数,同时两个新数的十位数字均不为零,则将满足此条件的四位数按从大到小的顺序存入数组b 中,并要计算满足上述条件的四位数的个数cnt 。 最后main()函数调用写函数writeDat( )把结果cnt 以及数组b 中符合条件的四位数输出到OUT.DAT 文件中。 注意:部分源程序存在文件prog1.c 中。 程序中已定义数组:a[200],b[200],已定义变量:cnt 请勿改动数据文件IN.DAT 中的任何数据、主函数main()、读函数readDat()和写函数writeDat()的内容。 #include ******************************* ★☆题目31(结构体运算题) 已知在文件IN.DAT 中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位),产品名称mc(字符型10位),单价dj(整型),数量sl(整型),金额je(长整型)五部分组成。其中:金额=单价*数量计算得出。函数ReadDat()是读取这100个销售记录并存入结构数组sell 中。请编制函数SortDat(),其功能要求:按金额从大到小进行排列,若金额相同,则按产品代码从大到小进行排列, 最终排列结果仍存入结构数组sell 中,最后调用函数WriteDat() 把结果输出到文件OUT4.DAT 中。 部分源程序存在文件prog1.c 中。 请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。 #include void SortDat() {int i,j; PRO xy; for(i=0;i<99;i++) for(j=i+1;j<100;j++) if(sell[i].je {xy=sell[i];sell[i]=sell[j];sell[j]=xy;} } void main() { memset(sell,0,sizeof(sell)); ReadDat(); SortDat(); WriteDat(); } void ReadDat() { FILE *fp; char str[80],ch[11]; int i; fp=fopen("IN.DAT","r"); for(i=0;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); } void WriteDat(void) { FILE *fp; int i; fp=fopen("OUT4.DAT","w"); for(i=0;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); } ***************************** ☆题目32(结构体运算题) 已知在文件IN.DA T中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位),产品名称mc(字符型10位),单价dj(整型),数量sl(整型),金额je(长整型)五部分组成。其中:金额=单价*数量计算得出。函数ReadDat()是读取这100个销售记录并存入结构数组sell 中。请编制函数SortDat(),其功能要求: 按产品名称从大到小进行排列,若产品 名称相等,则按金额从小到大进行排列, 最终排列结果仍存入结构数组sell中 ,最后调用函数WriteDat()把结果输出到 文件OUT7.DA T中。 部分源程序存在文件prog1.c中。 请勿改动主函数main()、读数据函数 ReadDat()和输出数据函数WriteDat()的 内容。 #include #include #include #include #include #define MAX 100 typedef struct{ char dm[5]; /*产品代码*/ char mc[11]; /*产品名称*/ int dj; /*单价*/ int sl; /*数量*/ long je; /*金额*/ }PRO; PRO sell[MAX]; void ReadDat(); void WriteDat(); 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;} } void main() { memset(sell,0,sizeof(sell)); ReadDat(); SortDat(); WriteDat(); } void ReadDat() { FILE *fp; char str[80],ch[11]; int i; 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); } void WriteDat() { FILE *fp; int i; fp=fopen("OUT7.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); } ******************************* ★☆题目33(方差运算题) 请编制函数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) 部分源程序存在文件prog1.c中。 请勿改动主函数main()和输出数据 函数writeDat()的内容。 #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 { fscanf(fp,"%d,",&xx[i]); if((i+1)%10==0) fscanf(fp,"\n"); } /**************************/ fclose(fp); return 0; } void Compute(void) { int i,yy[MAX]; for(i=0;i yy[i]=0; for(i=0;i if(xx[i]%2==0) { yy[even++]=xx[i]; ave2+=xx[i];} else { odd++; ave1+=xx[i];} if(odd==0) ave1=0; else ave1/=odd; if(even==0) ave2=0; else ave2/=even; for(i=0;i totfc+=(yy[i]-ave2)*(yy[i]-ave2)/even; } void main() { int i; for(i=0;i if(ReadDat()){ printf("数据文件IN.DAT不能打 开!\007\n"); return; } Compute(); printf("OVEN=%d\nA VE1=%f\nA VER2= %f\nTOTFC=%f\n",even,ave1,ave2,totfc); WriteDat(); } void WriteDat(void) { FILE *fp; int i; fp=fopen("OUT.DA T","w"); fprintf(fp,"%d\n%f\n%f\n%f\n",even,ave1, ave2,totfc); fclose(fp); } **************************** 题目34(素数题) 无忧id 102 题提供了求素数isPrime()函数 程序prog1.c的功能是:选出100以上1000之内所有个位数字与十位数字之和被10除所得余数恰是百位数字的素数(如293)。计算并输出上述这些素数的个数cnt以及这些素数值的和sum。请考生编写函数countValue( )实现程序要求,最后调用函数writeDAT()把结果cnt 和sum输出到文件bc10.out中。 注意:部分源程序存放在文件 prog1.c中。 请勿改动主函数main( )和输出数据函数writeDAT()的内容。 #include int cnt, sum ; int isPrime(int m) { int i; for(i=2;i if(m % i==0)return 0; return 1; } void countValue() { int i,j,bw,sw,gw; for(i=100;i<1000;i++) { bw=i/100; sw=i%100/10; gw=i%10; if(isPrime(i)&&(gw+sw)%10==bw) { cnt++; sum+=i;} } } void main() { cnt=sum=0; countValue() ; printf("素数的个数=%d\n", cnt) ; printf("满足条件素数值的和=%d", sum) ; writeDAT() ; } writeDAT() { FILE *fp ; fp = fopen("bc10.out", "w") ; fprintf(fp, "%d\n%d\n", cnt, sum) ; fclose(fp) ; } ****************************** ★☆题目35(级数运算题) 某级数的前两项A1=1,A2=1,以后各项 具有如下关系: An=An-2+2An-1(注:n-2与n-1为 下标) 下列程序prog1.c的功能是:要求依 次对于整数M=100,1000和10000求出 对应的n值,使其满足:Sn Sn+1>=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++; } } main() { jsValue(); printf("M=100,n=%d\nM=1000,n=%d\nM =10000,n=%d\n",b[0],b[1],b[2]); writeDat(); } writeDat() { FILE *fp; fp=fopen("out.dat","w"); printf("%d\n%d\n%d\n",b[0],b[1],b[2]); fprintf(fp,"%d\n%d\n%d\n",b[0],b[1],b[2]); fclose(fp); } 运行结果为: M=100,n=6 M=1000,n=9 M=10000,n=11 ******************************* ★题目36(字符替换题) 函数ReadDat()实现从文件ENG.IN中读 取一篇英文文章,存入到字符串数组xx 中;请编制函数encryptChar(),按给定的 替代关系对数组xx中的所有字符进行替 代,仍存入数组xx的对应的位置上,最 后调用函数WriteDat()把结果xx输出到 文件pS6.DA T中。 替代关系:f(p)=p*11 mod 256(p是 数组中某一个字符的ASCII值,f(p)是计 算后新字符的ASCII值),如果计算后f(p) 值小于等于32或f(p)对应的字符是数字 0至9,则该字符不变,否则将f(p)所对 应的字符进行替代。 部分源程序存在文件prog1.c中。原 始数据文件存放的格式是:每行的宽度 均小于80个字符。 请勿改动主函数main()、读数据函数 ReadDat()和输出数据函数WriteDat()的 内容。 #include #include #include #include unsigned char xx[50][80]; int maxline=0;/*文章的总行数*/ int ReadDat(void); void WriteDat(void); void encryptChar() { int i,j; for(i=0;i for(j=0;j if(xx[i][j]*11%256<=32||xx[i][j]*11%256 >='0'&&xx[i][j]*11%256<='9') continue; else xx[i][j]=xx[i][j]*11%256; } void main() { clrscr(); if(ReadDat()){ printf("数据文件ENG.IN不能打开!\n\007"); 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(xx[i],80,fp)!=NULL){ p=strchr(xx[i],'\n'); if(p)*p=0; i++; } maxline=i; fclose(fp); return 0; } void WriteDat(void) { FILE *fp; int i; fp=fopen("ps6.dat","w"); for(i=0;i printf("%s\n",xx[i]); fprintf(fp,"%s\n",xx[i]); } fclose(fp); } **************************** 题目37(字符替换题) 函数ReadDat()实现从文件ENG.IN中读取一篇英文文章,存入到字符串数组xx 中;请编制函数encryptChar(),按给定的替代关系对数组xx中的所有字符进行替代,仍存入数组xx的对应的位置上,最后调用函数WriteDat()把结果xx输出到文件PS7.DA T中。 替代关系:f(p)=p*11 mod 256(p是数组中某一个字符的ASCII值,f(p)是计算后新字符的ASCII值),如果原字符是大写字母或计算后f(p)值小于等于32,则该字符不变,否则将f(p)所对应的字符进行替代。 部分源程序存在文件prog1.c中。原 始数据文件存放的格式是:每行的宽度 均小于80个字符。 请勿改动主函数main()、读数据函数 ReadDat()和输出数据函数WriteDat()的 内容。 #include #include #include #include unsigned char xx[50][80]; int maxline=0;/*文章的总行数*/ int ReadDat(void); void WriteDat(void); void encryptChar() { int i,j; for(i=0;i for(j=0;j if(xx[i][j]*11%256<=32||xx[i][j]>='A'&& xx[i][j]<='Z') continue; else xx[i][j]=xx[i][j]*11%256; } void main() { clrscr(); if(ReadDat()){ printf("数据文件ENG.IN不能打开! \n\007"); 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(xx[i],80,fp)!=NULL){ p=strchr(xx[i],'\n'); if(p)*p=0; i++; } maxline=i; fclose(fp); return 0; } void WriteDat(void) { FILE *fp; int i; fp=fopen("ps7.dat","w"); for(i=0;i printf("%s\n",xx[i]); fprintf(fp,"%s\n",xx[i]); } fclose(fp); } ******************************** 题目38(结构体运算题) 已知在文件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 #define MAX 100 typedef struct{ char dm[5]; /*产品代码*/ char mc[11]; /*产品名称*/ int dj; /*单价*/ int sl; /*数量*/ long je; /*金额*/ }PRO; PRO sell[MAX]; void ReadDat(); void WriteDat(); 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>sel l[j].je) {xy=sell[i];sell[i]=sell[j];sell[j]=xy;} } void main() { memset(sell,0,sizeof(sell)); ReadDat(); SortDat(); WriteDat(); } void ReadDat() { FILE *fp; char str[80],ch[11]; int i; fp=fopen("IN.DA T","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); } void WriteDat(void) { FILE *fp; int i; 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); } ******************************* ★☆题目39(选票问题) 现有一个10个人100行的选票数据文件IN.DA T,其数据存放的格式是每条记录的长度均为10位,第一位表示第一个人的选中情况,第二位表示第二个人的选中情况,依此类推:内容均为字符0和1,1表示此人被选中,0表示此人未被选中,全选或不选均为无效的选票。给定函数ReadDat()的功能是把选票数据读入到字符串数组xx中。请编制函数CountRs()来统计每个人的选票数并把得票数依次存入yy[0]到yy[9]中。把结果yy输出到文件OUT.DA T中。 部分源程序存在文件prog1.c中。 请勿改动主函数main()、读数据函数ReadDat()和输出数据函数writeDat()的内容。 #include char xx[100][11]; int yy[10]; int ReadDat(void); void WriteDat(void); 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(count==0||count==10) continue; for(j=0;j<10;j++) if(xx[i][j]=='1') yy[j]++; } } void main() { int i; for(i=0;i<10;i++)yy[i]=0; if(ReadDat()){ printf("选票数据文件IN.DAT不能打 开!\n\007"); return; } CountRs(); WriteDat(); } int ReadDat(void) { FILE *fp; int i; if((fp=fopen("IN.DA T","r")) == NULL) return 1; for(i=0;i<100;i++){ if(fgets(xx[i],11,fp)==NULL)return 1; xx[i][10]='\0'; } fclose(fp); return 0; } void WriteDat(void) { FILE *fp; int i; fp=fopen("OUT.DAT","w"); for(i=0;i<10;i++){ fprintf(fp,"%d\n",yy[i]); printf("第%d个人的选票数 =%d\n",i+1,yy[i]); } fclose(fp); } ****************************** ☆题目40(整数统计运算题) 已知在文件IN.DAT中存有若干个(个数 <200)四位数字的正整数,函数ReadDat() 读取这若干个正整数并存入数组xx中。 请编制函数CalValue(),其功能要求: 1、求出这文件中共有多少个正整数 totNum; 2、求这些数中的各位数字之和是偶数的 数的个数totCnt, 以及满足此条件的这些数的算术平均值 totPjz,最后调用函数writeDat()把所求的 结果输出到文件OUT.DAT中。 部分源程序存在文件prog1.c中。 请勿改动主函数main()、读函数 ReadDat()和写函数writeDat()的内容。 #include #include #define MAXNUM 200 int xx[MAXNUM]; int totNum=0; /*文件IN.DA T中共有多少 个正整数*/ int totCnt=0; /*符合条件的正整数的个数 */ double totPjz=0.0; /*平均值*/ int ReadDat(void); void writeDat(void); void CalValue(void) { int i,qw,bw,sw,gw; for(i=0;i if(xx[i]>0) { totNum++; qw=xx[i]/1000; bw=xx[i]/100%10; sw=xx[i]%100/10; gw=xx[i]%10; if((qw+bw+sw+gw)%2==0) { totCnt++; totPjz+=xx[i];} } if(totCnt==0) totPjz=0; else totPjz/=totCnt; } void main() { int i; clrscr(); for(i=0;i if(ReadDat()){ printf("数据文件IN.DA T不能打 开!\007\n"); return; } CalValue(); printf("文件IN.DAT中共有正整数=%d 个\n",totNum); printf("符合条件的正整数的个数=%d个 \n",totCnt); printf("平均值=%.2f\n",totPjz); writeDat(); } int ReadDat(void) { FILE *fp; int i=0; if((fp=fopen("IN.DAT","r"))==NULL) return 1; while(!feof(fp)){ fscanf(fp,"%d,",&xx[i++]); } fclose(fp); return 0; } void writeDat(void) { FILE *fp; fp=fopen("OUT.DA T","w"); fprintf(fp,"%d\n%d\n%6.2f\n",totNum,totC nt,totPjz); fclose(fp); } ***************************** ☆题目41(SIX/NINE问题) 下列程序prog1.c的功能是:计算出自然数SIX和NINE,它们满足的条件是SIX+SIX+SIX=NINE+NINE的个数cnt 以及满足此条件所有的SIX与NINE的和SUM。请编写函数countValue()实现程序的要求,最后调用函数writeDat()把结果cnt和sum,输出到文件OUT15.DAT 中。 其中的S,I,X,N,E各代表一个十进制数字。 部分源程序存在文件prog1.c中。 请勿改动主函数main()和输出数据函数writeDat()的内容。 #include int cnt,sum; void countValue() { int s,i,x,n,e,six,nine; for(s=1;s<10;s++) for(i=0;i<10;i++) for(x=0;x<10;x++) for(n=1;n<10;n++) for(e=0;e<10;e++) { six=s*100+i*10+x; nine=n*1000+i*100+n*10+e; if(3*six==2*nine) { cnt++;sum+=six+nine;} } } void main() { cnt=sum=0; countValue(); printf("满足条件的个数=%d\n",cnt); printf("满足条件所有的SIX与NINE的和=%d\n",sum); writeDat(); } writeDat() { FILE *fp; fp=fopen("OUT15.DA T","w"); fprintf(fp,"%d\n%d\n",cnt,sum); fclose(fp); } ***************************** 题目42 结构体运算题 已知在文件IN.DA T中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位),产品名称mc(字符型10位),单价dj(整型),数量sl(整型),金额je(长整型)五部分组成。其中:金额= 单价*数量计算得出。函数ReadDat()是读 取这100个销售记录并存入结构数组sell 中。请编制函数SortDat(),其功能要求: 按产品名称从大到小进行排列,若产品 名称相等,则按金额从大到小进行排列, 最终排列结果仍存入结构数组sell中,最 后调用函数WriteDat()把结果输出到文件 OUT5.DA T中。 部分源程序存在文件prog1.c中。 请勿改动主函数main()、读数据函数 ReadDat()和输出数据函数WriteDat()的 内容。 #include #include #include #include #include #define MAX 100 typedef struct{ char dm[5]; /*产品代码*/ char mc[11]; /*产品名称*/ int dj; /*单价*/ int sl; /*数量*/ long je; /*金额*/ }PRO; PRO sell[MAX]; void ReadDat(); void WriteDat(); 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 j].je) {xy=sell[i];sell[i]=sell[j];sell[j]=xy;} } void main() { memset(sell,0,sizeof(sell)); ReadDat(); SortDat(); WriteDat(); } void ReadDat() { FILE *fp; char str[80],ch[11]; int i; fp=fopen("IN.DA T","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); } void WriteDat() { FILE *fp; int i; fp=fopen("OUT5.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); } ***************************** ★题目43(字符排序题) 无忧id 82题(只是将结果按“从大到小” 排序) 函数ReadDat()实现从文件in.dat中读取 20行数据存放到字符串数组xx中(每行 字符串长度均小于80)。请编制函数 jsSort(),其函数的功能是:以行为单位 对字符串变量的下标为奇数的字符按其 ASCII值从小到大的顺序进行排序,排序 后的结果仍按行重新存入字符串数组xx 中,最后调用函数WriteDat()把结果xx 输出到文件out.dat中。 例如:位置01234567 源字符串 a b c d e f g h 则处理后字符串a h c f e d g b 部分源程序存在文件prog1.c中。 请勿改动主函数main()、读数据函数 ReadDat()和输出数据函数WriteDat()的 内容。 #include #include #include char xx[20][80]; void jsSort() {int i,j,k,strl; char ch; for(i=0;i<20;i++) { strl=strlen(xx[i]); for(j=1;j for(k=j+2;k if(xx[i][j]>xx[i][k]) { ch=xx[i][j];xx[i][j]=xx[i][k];xx[i][k]=ch ;} } } void main() { readDat(); jsSort(); writeDat(); } readDat() { FILE *in; int i=0; char *p; in=fopen("in.dat","r"); while(i<20&&fgets(xx[i],80,in)!=NULL){ p=strchr(xx[i],'\n'); if(p)*p=0; i++; } fclose(in); } writeDat() { FILE *out; int i; out=fopen("out.dat","w"); clrscr(); for(i=0;i<20;i++){ printf("%s\n",xx[i]); fprintf(out,"%s\n",xx[i]); } fclose(out); } *************************** ★☆题目44(字符串左右排序交换题)函数ReadDat()实现从文件in.dat中读取20行数据存放到字符串数组xx中(每行字符串长度均小于80)。请编制函数jsSort(),其函数的功能是:以行为单位对字符串按给定的条件进行排序,排序后的结果仍按行重新存入字符串数组xx 中,最后调用函数WriteDat()把结果xx 输出到文件out.dat中。 条件:从字符串中间一分为二,左边部分按字符的ASCII值降序排序,排序后左边部分与右边部分进行交换。如果原字符串长度为奇数,则最中间的字符不参加处理,字符仍放在原位置上。 例如:位置01234 5678 源字符串 a b c d h g f e 1 2 3 4 9 8 7 6 5 则处理后字符串h g f e d c b a 8 7 6 5 9 4 3 2 1 部分源程序存在文件prog1.c中。 请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。 #include #include #include void jsSort() { int i,j,k,strl,half; char temp; for(i=0;i<20;i++) { strl=strlen(xx[i]); half=strl/2; for(j=0;j for(k=j+1;k if(xx[i][j] { temp=xx[i][j]; xx[i][j]=xx[i][k]; xx[i][k]=temp;} for(j=half-1,k=strl-1;j>=0;j--,k--) { temp=xx[i][j]; xx[i][j]=xx[i][k]; xx[i][k]=temp;} } } void main() { readDat(); jsSort(); writeDat(); } readDat() { FILE *in; int i=0; char *p; in=fopen("in.dat","r"); while(i<20&&fgets(xx[i],80,in)!=NULL){ p=strchr(xx[i],'\n'); if(p)*p=0; i++; } fclose(in); } writeDat() { FILE *out; int i; clrscr(); out=fopen("out.dat","w"); for(i=0;i<20;i++){ printf("%s\n",xx[i]); fprintf(out,"%s\n",xx[i]); } fclose(out); } ************************** ★题目45(数字统计排序题) 已知数据文件IN.DAT中存有200个四位 数,并已调用读函数readDat()把这些数 存入数组a中,请考生编制一函数 jsVal(),其功能是:依次从数组a中取出 一个四位数,如果该四位数连续大于该 四位数以前的五个数且该数是偶数(该 四位数以前不满五个数,则不统计),则 统计出满足此条件的个数cnt并把这些四 位数按从大到小的顺序存入数组b中, 最后调用写函数writeDat( )把结果cnt以 及数组b中符合条件的四位数输出到 OUT.DAT文件中。 注意:部分源程序存在文件prog1.c 中。 程序中已定义数组:a[200],b[200], 已定义变量:cnt 请勿改动数据文件IN.DA T中的任 何数据、主函数main()、读函数readDat() 和写函数writeDat()的内容。 #include #define MAX 200 int a[MAX], b[MAX], cnt = 0 ; void jsVal() {int i,j,flag; for(i=5;i {for(j=i-5;j if(a[i]>a[j]&&a[i]%2==0) flag=1; else { flag=0; break;} if(flag==1) b[cnt++]=a[i]; } for(i=0;i for(j=i+1;j if(b[i] {flag=b[i];b[i]=b[j];b[j]=flag;} } void readDat() { int i ; FILE *fp ; fp = fopen("in.dat", "r") ; for(i = 0 ; i < MAX ; i++) fscanf(fp, "%d", &a[i]) ; fclose(fp) ; } void main() { int i ; readDat() ; jsVal() ; printf("满足条件的数=%d\n", cnt) ; for(i = 0 ; i < cnt ; i++) printf("%d ", b[i]) ; printf("\n") ; writeDat() ; } writeDat() { FILE *fp ; int i ; fp = fopen("out.dat", "w") ; fprintf(fp, "%d\n", cnt) ; for(i = 0 ; i < cnt ; i++) fprintf(fp, "%d\n", b[i]) ; fclose(fp) ; } ************************** ☆题目46(数字统计排序题) 已知数据文件IN.DAT中存有200个四位数,并已调用读函数readDat()把这些数存入数组a中,请考生编制一函数 jsVal(),其功能是:依次从数组a中取出一个四位数,如果该四位数连续大于该四位数以前的五个数且该数是奇数,且该数必须能被7整除(该四位数以前不满五个数,则不统计),则统计出满足此条件的个数cnt并把这些四位数按从大到小的顺序存入数组b中,最后调用写函数writeDat( )把结果cnt以及数组b中符合条件的四位数输出到OUT.DAT文件中。 注意:部分源程序存在文件prog1.c 中。 程序中已定义数组:a[200],b[200],已定义变量:cnt 请勿改动数据文件IN.DAT中的任 何数据、主函数main()、读函数readDat()和写函数writeDat()的内容。 #include #define MAX 200 int a[MAX], b[MAX], cnt = 0 ; void jsVal() { int i,j,flag; for(i=5;i { for(j=i-5;j if(a[i]>a[j]&&a[i]%2&&a[i]%7==0) flag=1; else { flag=0;break;} if(flag==1) b[cnt++]=a[i]; } for(i=0;i for(j=i+1;j if(b[i] b[j]=flag;} } void readDat() { int i ; FILE *fp ; fp = fopen("in.dat", "r") ; for(i = 0 ; i < MAX ; i++) fscanf(fp, "%d", &a[i]) ; fclose(fp) ; } void main() { int i ; readDat() ; jsVal() ; printf("满足条件的数=%d\n", cnt) ; for(i = 0 ; i < cnt ; i++) printf("%d ", b[i]) ; printf("\n") ; writeDat() ; } writeDat() { FILE *fp ; int i ; fp = fopen("out.dat", "w") ; fprintf(fp, "%d\n", cnt) ; for(i = 0 ; i < cnt ; i++) fprintf(fp, "%d\n", b[i]) ; fclose(fp) ; } ******************************* 题目47(结构体运算题) 已知在文件IN.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位),产品名称mc(字符型10位),单价dj(整型),数量sl(整型),金额je(长整型)五部分组成。其中:金额=单价*数量计算得出。函数ReadDat()是读取这100个销售记录并存入结构数组sell 中。请编制函数SortDat(),其功能要求:按金额从大到小进行排列,若金额相等,则按产品代码从小到大进行排列,最终排列结果仍存入结构数组sell中,最后调用函数WriteDat()把结果输出到文件OUT3.DA T中。 部分源程序存在文件prog1.c中。 请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的 内容。 #include #include #include #include #include #define MAX 100 typedef struct{ char dm[5]; /*产品代码*/ char mc[11]; /*产品名称*/ int dj; /*单价*/ int sl; /*数量*/ long je; /*金额*/ }PRO; PRO sell[MAX]; void ReadDat(); void WriteDat(); void SortDat() {int i,j; PRO xy; for(i=0;i<99;i++) for(j=i+1;j<100;j++) if(sell[i].je {xy=sell[i];sell[i]=sell[j];sell[j]=xy;} } void main() { memset(sell,0,sizeof(sell)); ReadDat(); SortDat(); WriteDat(); } void ReadDat() { FILE *fp; char str[80],ch[11]; int i; 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); } void WriteDat() { FILE *fp; int i; fp=fopen("OUT3.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); } ***************************** ☆题目48(整数各位数字运算题) 已知数据文件in.dat中存有300个四位数,并已调用读函数ReadDat()把这些数存入数组a中,请编制一函数jsValue(),其功能是:求出千位数上的数加个位数上的数等于百位数上的数加十位数上的数的个数cnt,再把所有满足此条件的四位数依次存入数组b中,然后对数组b 的四位数按从小到大的顺序进行排序,最后调用写函数writeDat()把结果输出到out.dat文件。 例如:6712,6+2=7+1,则该数满足条件存入数组b中,且个数cnt=cnt+1。 8129,8+9<>1+2,则该数不满足条件忽略。 部分源程序存在文件prog1.c中。 程序中已定义数组:a[300],b[300],已定义变量:cnt 请勿改动主函数main()、读函数ReadDat()和写函数writeDat()的内容。 #include int a[300],b[300],cnt=0; jsValue() {int i,qw,bw,sw,gw,j; for(i=0;i<300;i++) {qw=a[i]/1000; bw=a[i]%1000/100; sw=a[i]%100/10; gw=a[i]%10; if(qw+gw==bw+sw) b[cnt++]=a[i]; } for(i=0;i for(j=i+1;j if(b[i]>b[j]) {qw=b[i]; b[i]=b[j]; b[j]=qw;} } main() { int i; readDat(); jsValue(); writeDat(); printf("cnt=%d\n",cnt); for(i=0;i printf("b[%d]=%d\n",i,b[i]); } readDat() { FILE *fp; int i; fp=fopen("in.dat","r"); for(i=0;i<300;i++)fscanf(fp,"%d,",&a[i]); fclose(fp); } writeDat() { FILE *fp; int i; fp=fopen("out.dat","w"); fprintf(fp,"%d\n",cnt); for(i=0;i } ******************************** 题目49(整数各位数字运算题) 已知数据文件in.dat中存有300个四位数,并已调用读函数ReadDat()把这些数存入数组a中,请编制一函数jsValue(),其功能是:求出千位数上的数减百位数减十位数上的数减个位数上的数大于零的个数cnt,再求出所有满足此条件的四位数平均值pjz1,以及不满足此条件的四位数平均值pjz2,最后调用写函数writeDat()把结果输出到out.dat文件。 例如:9123,9-1-2-3>0,则该数满足条件计算平均值pjz1,且个数cnt=cnt+1。9812,9-8-1-2<0,则该数不满足条件计算 平均值pjz2。 部分源程序存在文件prog1.c中。 程序中已定义数组:a[300],已定义变量:cnt,pjz1,pjz2。 请勿改动主函数main()、读函数ReadDat()和写函数writeDat()的内容。 #include int a[300],cnt=0; double pjz1=0.0,pjz2=0.0; jsValue() {int i,qw,bw,sw,gw,n=0; for(i=0;i<300;i++) {qw=a[i]/1000; bw=a[i]%1000/100; sw=a[i]%100/10; gw=a[i]%10; if(qw-bw-sw-gw>0) {cnt++;pjz1+=a[i];} else {n++;pjz2+=a[i];} } if(cnt==0) pjz1=0; else pjz1/=cnt; if(n==0) pjz2=0; else pjz2/=n; } main() { int i; readDat(); jsValue(); writeDat(); printf("cnt=%d\n满足条件的平均值 pzj1=%7.2f\n不满足条件的平均值 pzj2=%7.2f\n",cnt,pjz1,pjz2); } readDat() { FILE *fp; int i; fp=fopen("in.dat","r"); for(i=0;i<300;i++)fscanf(fp,"%d,",&a[i]); fclose(fp); } writeDat() { FILE *fp; int i; fp=fopen("out.dat","w"); fprintf(fp,"%d\n%7.2f\n%7.2f\n",cnt,pjz1,p jz2); fclose(fp); } ********************************** 题目50(字符串左右排序交换题) 函数ReadDat()实现从文件in.dat中读取20行数据存放到字符串数组xx中(每行字符串长度均小于80)。请编制函数jsSort(),其函数的功能是:以行为单位对字符串按给定的条件进行排序,排序后的结果仍按行重新存入字符串数组xx 中,最后调用函数WriteDat()把结果xx 输出到文件out.dat中。 条件:从字符串中间一分为二,左边部分按字符的ASCII值升序排序,排序后左边部分与右边部分进行交换。如果原字符串长度为奇数,则最中间的字符不参加处理,字符仍放在原位置上。 例如:位置01234 5678 源字符串 d c b a h g f e 4 3 2 1 9 8 7 6 5 则处理后字符串h g f e a b c d 8 7 6 5 9 1 2 3 4 部分源程序存在文件prog1.c中。 请勿改动主函数main()、读函数ReadDat()和写函数WriteDat()的内容。 #include #include #include char xx[20][80]; void jsSort() { int i,j,k,strl,half; char temp; for(i=0;i<20;i++) { strl=strlen(xx[i]); half=strl/2; for(j=0;j for(k=j+1;k if(xx[i][j]>xx[i][k]) { temp=xx[i][j]; xx[i][j]=xx[i][k]; xx[i][k]=temp;} for(j=half-1,k=strl-1;j>=0;j--,k--) { temp=xx[i][j]; xx[i][j]=xx[i][k]; xx[i][k]=temp;} } } void main() { readDat(); jsSort(); writeDat(); } readDat() { FILE *in; int i=0; char *p; in=fopen("in.dat","r"); while(i<20 && fgets(xx[i],80,in)!=NULL){ p=strchr(xx[i],'\n'); if(p) *p=0; i++; } fclose(in); } writeDat() { FILE *out; int i; clrscr(); out=fopen("out.dat","w"); for(i=0;i<20;i++){ printf("%s\n",xx[i]); fprintf(out,"%s\n",xx[i]); } fclose(out); } **************************** ★☆题目51(整数各位打散组合运算题)