国家计算机等级考试三级C程序实例200题_第1页
国家计算机等级考试三级C程序实例200题_第2页
国家计算机等级考试三级C程序实例200题_第3页
国家计算机等级考试三级C程序实例200题_第4页
国家计算机等级考试三级C程序实例200题_第5页
已阅读5页,还剩210页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

☆题目1

请编写一个函数jsValue(intm,intk,intxx[]),该函数的功

能是:将大于整数m且紧靠m的k个素数存入数组xx传回。

最后调用函数writeDat。读取10组数据,分别得出结果且把结果输出到文件out.dat中。

部分源程序存在文件progl.c中。

例如:若输入175则应输出:19,23,29,31,37。

请勿改动主函数main。和写函数writeDat。的内容。

#include<conio.h>

#include<stdio.h>

voidreadwriteDat();

intisP(intm)

(

inti;

for(i=2;i<m;i++)

if(m%i==0)return0;

return1;

)

voidnum(intm,inlkjntxx[])

{ints=0;

for(m=m+1;k>0;m++)

if(isP(m)){xx[s++]=m;k--;}

)

main()

(

intm,n,xxll000J;

clrscr();

printf(n\nPleaseentertwointegers:");

scanf("%d%d",&m,&n);

num(m,n,xx);

for(m=0;m<n;m++)

printf(n%du,xx[m]);

printf(n\nn);

readwriteDat();

)

voidreadwriteDat()

(

intm,n,xx[1000],i;

FILE

rf=fopen(,'in.dat,,,*'rH);

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<n;m++)fprintf(wf,,,%dn,xx[m]);

fprintf(wf,"\n,');

)

fclose(rf);

fclose(wf);

☆题目2

一知数据文件IN.DAT中存有200个四位数,并己调用读函数readDat()把这些数存入数组a

中,请考生编制一函数jsVal(),其功能是:如果四位数各位上的数字均是0或2或4或6或

8,则统计出满足此条件的个数ent,并把这些四位数按从大到小的顺序存入数组b中。最后

main()函数调用写函数writeDat()把结果ent以及数组b中符合条件的四位数输出到

OUT.DAT文件中。

注意:部分源程序存在文件progl.c中。

程序中已定义数组:a[200],b[200],已定义变量:ent

请勿改动数据文件IN.DAT中的任何数据、主函数main。、读函数readDat。和写函数writeDat()

的内容。

#include<stdio.h>

#defineMAX200

intalMAXJ,b[MAXJ,ent=0;

voidjsVal()

{inti,j,qw,bw,sw,gw;

for(i=0;i<MAX;i++)

{qw=a[i]/1000;bw=a[i]/100%10;

sw=alij%100/I0;gw=ali]%10;

if(qw&&qw%2==0&&bw%2==0&&sw%2==0&&gw%2==0)b[cnt++]=a[i];

)

for(i=0;i<cnt-l;i++)

fbr(j=i+1;j<cnt;j++)

if(b[i]<b[jl){qw=b[i];b[i]=b[j];b[j]=qw;}

)

voidreadDat()

(

inti;

FILE*fp;

fp=fopen("in.datM,nrn);

for(i=0;i<MAX;i++)fscanf(fp,u%du,&a[i]);

fclose(fp);

)

voidmain()

(

inti;

readDat();

jsVal();

printf("满足条件的数=%d\n”,ent);

for(i=0;i<ent;i++)printf("%d",b[i]);

printf("\nn);

writeDat();

writeDat()

(

FILE*fp;

inti;

fp=fopen(nout.dat",nwu);

fprintf(fp,"%d\n",ent);

for(i=0;i<ent;i++)fprintf(fp,n%d\n",b[i]);

fclose(fp);

)

★题目3

函数ReadDat()实现从文件IN.DAT中读取一篇英文文章存入到字符串数组xx中;请编制函

数StrOR(),其函数的功能是:以行为单位依次把字符串中所有小写字母。左边的字符串内

容移到该串的右边存放,然后把小写字母。删除,余下的字符串内容移到已处理字符串的左

边存放,之后把已处理的字符串仍按行重新存入字符串数组xx中。最后main。函数调用函

数WriteDat()把结果xx输出到文件OUT5.DAT中。

原始数据文件存放的格式是:每行的宽度均小于80个字符,含标点符号和空格。

注意:部分源程序存放在文件progl.c中。

请勿改动主函数main。、读数据函数ReadDat。和输出数据函数WriteDat()的内容。

#include<stdio.h>

#include<string.h>

#include<conio.h>

charxx[50Jl80J;

intmaxline=0;/*文章的总行数*/

intReadDat(void);

voidWriteDat(void);

voidStrOR(void)

{inti,righto,j,s,k;

chartem[80];

for(i=0;i<maxline;i++)

for(j=strlen(xx[i])-l;j>=0;j-)

{k=0;

memset(tem,0,80);

if(xx[i]Ul==,o,)

{righto=j;

for(s=righto+1;s<strlen(xx[i]);s++)

tem[k++]=xx[i][s];

for(s=0;s<righto;s++)

if(xx[i][s]!='o)

tem[k++]=xx[i][s];

strcpy(xx[i],tem);

)

elsecontinue;

)

)

voidmain()

(

clrscr();

if(ReadDat()){

printf("数据文件IN.DAT不能打开!\n\007");

return;

)

StrOR();

WriteDat();

)

intReadDat(void)

(

FILE*fp;

inti=0;

char*p;

if((fp=fopen(nIN.DAT",Y'))==NULL)return1;

whne(fgets(xx[i],80,fp)!=NULL){

p=strchr(xx[ij,*\n');

if(p)*p=0;

i++;

)

maxline=i;

fclose(fp);

return0;

)

voidWriteDat(void)

(

FILE*fp;

inti;

clrscr();

fp=fopen("OUT5.DATn,nw,r);

for(i=0;i<maxline;i++){

printf(M%s\n",xx[i]);

fprintf(fp,n%s\nM,xx[i]);

)

fclose(fp);

)

★题目4

函数ReadDat。实现从文件IN.DAT中读取一篇英文文章存入到字符串数组xx中,请编制函

数StrOL(),其函数的功能是:以行为单位对行中以空格或标点符号为分隔的所有单词进行

倒排。最后把已处理的字符串(应不含标点符号)仍按行重新存入字符串数组xx中,最后

调用函数writeDat()把结果xx输出到文件OUT6.DAT中。

例如:原文:YouHeMe

Iamastudent.

结果:MeHeYou

studentaamI

原始数据文件存放的格式是:每行的宽度均小于80个字符,含标点符号和空格。

部分源程序存在文件progl.c中。

请勿改动主函数main。、读数据函数ReadDat。和输出数据函数writeDat。的内容。

#include<stdio.h>

#include<string.h>

#include<conio.h>

#include<ctype.h>

charxx[50][80];

intmaxline=0;/*文章的总行数*/

intReadDat(void);

voidWriteDat(void);

voidStrOL(void)

{inti,j,k,s,m,strl;

charstr[8O];

for(i=0;i<maxline;i++)

{strl=strlen(xx[i]);

memset(str,0,80);

s=k=0;

for(j=strl-l;j>=O;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]=W;

strcpy(xx[i],str);)

)

voidmain()

(

clrscr();

if(ReadDat()){

printf("数据文件IN.DAT不能打开!\n\007");

return;

)

StrOL();

WriteDat();

)

intReadDat(void)

(

FILE*fp;

inti=0;

char*p;

if((fp=fopen(nIN.DAT";'ru))==NULL)return1;

while(fgets(xx[i],80,fp)!=NULL){

p=strchr(xxli]/\n');

if(p)*p=O;

i++;

)

maxline=i;

fclose(fp);

return0;

)

voidWriteDat(void)

(

FILE*fp;

inti;

clrscr();

fp=fopen("OUT6.DAT',,uw,');

for(i=0;i<maxline;i++){

printf("%s\n”,xx[i]);

fprintf(fp,"%s\n",xx[i]);

)

fclose(fp);

☆题目5(整数排序题)

在文件in.dat中有200个正整数,且每个数均在1000至9999之间。函数ReadDat。读取这

200个数存放到数组aa中。请编制函数jsSort(),其函数的功能是:要求按每个数的后三位

的大小进行升序排列,然后取出满足此条件的前10个数依次存入数组bb中,如果后三位的

数值相等,则按原先的数值进行降序排列。最后调用函数WriteDat()把结果bb输出到文件

out.dat中o

例:处理前60125099901270258088

处理后90126012702580885099

部分源程序存在文件progl.c中。

请勿改动主函数main()^读数据函数ReadDat()和输出数据函数WriteDal。的内容。

#include<stdio.h>

#include<string.h>

#include<conio.h>

intaa[200],bb[10];

voidjsSort()

(

inti,j,data;

for(i=0;i<I99;i++)

for(j=i+1;j<200;j++)if(aa[i]%1000>aa[j]%l000llaa[i]%lOOO==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];

voidmain()

(

readDat();

jsSort();

writeDat();

)

readDat()

(

FILE*in;

inti;

in=fopen(Hin.dat","r");

for(i=0;i<200;i++)fscanf(in,u%d,",&aa[i]);

fclose(in);

)

writeDat()

(

FILE*out;

inti;

clrscr();

out=fopen(,'out.dat,\',wH);

for(i=0;i<10;i++){

printfC1%du,bb[i]);

fprintf(out,,,%d\n,',bb[i]);

)

fclose(out);

)

☆题目6正整数排序

在文件in.dat中有200个正整数,且每个数均在1000至9999之间。函数ReadDat()读取这

200个数存放到数组aa中。请编制函数jsSort(),其函数的功能是:要求按每个数的后三位

的大小进行降序排列,然后取出满足此条件的前10个数依次存入数组b中,如果后三位的

数值相等,则按原先的数值进行升序排列。最后调用函数WriteDat。把结果bb输出到文件

oul.dat中。

例:处理前90125099601270258088

处理后50998088702560129012

注意:部分源程序已给出。

请勿改动主函数main。、读数据函数ReadDat。和输出数据函数WriteDat()的内容。

#inciude<stdio.h>

#include<string.h>

#include<conio.h>

intaa[200],bb[10];

voidjsSort()

(

inti,j,data;

for(i=0;i<199;i++)

for(j=i+l;j<200;j++)

if(aa[i]%1000<aa[j]%1000llaa[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];

}

voidmain()

(

readDat();

jsSort();

writeDat();

system(Hpause");

}

readDat()

(

FILE*in;

inti;

in=fopen("in.dat",T');

for(i=0;i<200;i++)fscanf(in,u%d,M,&aa[i]);

fclose(in);

)

writeDat()

(

FILE*out;

inti;

clrscr();

out=fopen(nout.dat",Hw");

for(i=0;i<10;i++){

printf(,,i=%d,%d\n,,,i+l,bb[i]);

fprintf(out,"%d\nM,bb[i]);

)

fclose(out);

)

☆题目7(结构体操作题)

已知在文件IN.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型

4位),产品名称me(字符型10位),单价dj(整型),数量si(整型),金额je(长整型)五部分组

成。其中:金额=单价*数量计算得出。函数ReadDatO是读取这100个销售记录并存入结构

数组sell中。请编制函数SortDat(),其功能要求:按产品代码从大到小进行排列,若产品代

码相同,则按金额从大到小进行排列,最终排列结果仍存入结构数组sell中,最后调用函数

WriteDat。把结果输出到文件OUT6.DAT中。

部分源程序存在文件progl.c中。

请勿改动主函数main。、读数据函数ReadDat()和输出数据函数WriteDat()的内容。

#include<stdio.h>

#include<mem.h>

#include<string.h>

#include<conio.h>

#include<stdlib.h>

#defineMAX100

typedefstruct{

chardm[5];/*产品代码*/

char产品名称*/

intdj;/*单价*/

intsi;/*数量*/

longje;/*金额*/

}PRO;

PROselllMAXJ;

voidReadDat();

voidWriteDat();

voidSortDat()

{inti,j;

PROxy;

for(i=0;i<99;i++)

for(j=i+l;j<100;j++)

if(strcmp(sell[il.dm,sell[j].dm)<Ollstrcmp(sellfi].dm,sellfj].dm)==O&&sell[i].je<sell[j].je)

{xy=sell[i];sell[ij=sell[jj;sell[j]=xy;}

voidmain()

(

memset(sell,0,sizeof(sell));

ReadDat();

SortDat();

WriteDat();

)

voidReadDat()

(

FILE*fp;

charstr[8O],ch[ll];

inti;

fp=fopen("IN.DAT"/r");

for(i=0;i<100;i++){

fgets(str,8O,fp);

memcpy(sell[i].dm,str,4);

memcpy(sell[i].mc,str+4,l0);

memcpy(ch,str+l4,4);ch[4]=0;

sell[i].dj=atoi(ch);

memcpy(ch,str+18,5);ch[5J=0;

sell[i].sl=atoi(ch);

sell[ij.je=(long)sellli].dj*selllij.sl;

)

fclose(fp);

)

voidWriteDat(void)

(

HLE*fp;

inti;

fp=fopen(,,OUT6.DAT'V'w'');

for(i=0;i<100;i++){

printf(M%s%s%4d%5d%5d\nn,sellli].dm,sell[ij.mc,sellli].dj,sell[i].sl,sell[i].je);

fprintf(fp,n%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.DAT中。

替代关系:f(p)=p*llmod256(p是数组中某一个字符的ASCII值,f(p)是计算后新字

符的ASCII值),如果计算后f(p)值小于等于32或大于130,则该字符不变,否则将f(p)所

对应的字符进行替代。(注意中间变量用无符号整型),部分源程序存在文件progl.c中。原

始数据文件存放的格式是:每行的宽度均小于80个字符。

请勿改动主函数main。、读数据函数ReadDat()和输出数据函数WriteDat。的内容。

#include<stdio.h>

#include<string.h>

#include<conio.h>

#include<ctype.h>

unsignedcharxx[50][80];

intmaxline=0;/*文章的总行数*/

intReadDat(void);

voidWriteDat(void);

voidencryptChar()

{inti,j;

for(i=0;i<maxline;i++)

for(j=0;j<strlen(xx[i]);j++)

if(xx[i][j]*11%256<=32llxx[i][j]*11%256>130)continue;

elsexx[i][j]=xx[i][j]*l1%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=O;

i++;

)

maxline=i;

fclose(fp);

return0;

)

voidWriteDat(void)

(

FILE*fp;

inti;

fp=fopen("psl.dat'V'w");

for(i=0;i<maxline;i++){

printf("%s\n”,xx[i]);

fprintf(fp,"%s\nn,xx[i]);

)

fclose(fp);

)

★☆题目9(字符串排序题)

函数ReadDat()实现从文件IN.DAT中读取一篇英文文章存入到字符串数组xx中,请编制函

数SortCharDO,其函数的功能是:以行为单位对字符按从大到小的顺序进行排序,排序后

的结果仍按行重新存入字符串数组xx中,最后调用函数writeDat()把结果xx输出到文件

OUT2.DAT中。

例:原文:dAe,BfC.

CCbbAA

结果:fedCBA.

bbCCAA

原始数据文件存放的格式是:每行的宽度均小于80个字符,含标点符号和空格。

部分源程序存在文件progl.c中。

请勿改动主函数main()^读数据函数ReadDat()和输出数据函数writeDat。的内容。

#include<stdio.h>

#include<string.h>

#include<conio.h>

charxx[50][80J;

intmaxline=O;/*文章的总行数*/

intReadDat(void);

voidWriteDat(void);

voidSortCharD(void)

{inti,j,k,strl;

charch;

for(i=0;i<maxline;i++)

{strl=strlen(xx[i]);

for(j=0;j<strl-l;j++)

for(k=j+1;k<strl;k++)

if(xx[i]U]<xx[i][k])

{ch=xx[i][j];xx[i][j]=xx[i][k];xx[i][k]=ch;)

voidmain()

(

clrscr();

if(ReadDat()){

printf("数据文件IN.DAT不能打开!\n\007M);

return;

)

SoilCharD();

WriteDat();

)

intReadDat(void)

(

FILE*fp;

inti=0;

char*p;

if((fp=fopen(MIN.DAT,';,r"))==NULL)return1;

while(fgets(xx[i],80,fp)!=NULL){

p=strchr(xx[i]/\n,);

if(p)*p=O;

i++;

maxline=i;

fclose(fp);

return0;

voidWriteDat(void)

(

FILE*fp;

inti;

fp=fopen(',OUT2.DAT",uw");

for(i=0;i<maxline;i++){

printf(n%s\nn,xx[i]);

fprintf(fp,n%s\nn,xx[i]);

}

fclose(fp);

}

★☆题目10(替换字符题)

函数ReadDat。实现从文件IN.DAT中读取•篇英文文章存入到字符串数组xx中,请编制函

数ConvertCharA(),其函数的功能是:以行为单位把字符串中的所有小写字母改写成该字母

的下一个字母,如果是字母z,则改写成字母a。大写字母仍为大写字母,小写字母仍为小

写字母,其他字符不变。把己处理的字符串仍按行重新存入字符串数组xx中,最后调用函

数writeDat。把结果xx输出到文件OUT1.DAT中。

例:原文:Adb.Bcdza

abck.LLhj

结果:Aec.Bdeab

bcdl.LLik

原始数据文件存放的格式是:每行的宽度均小于80个字符,含标点符号和空格。

部分源程序存在文件progl.c中。

请勿改动主函数main。、读数据函数ReadDat。和输出数据函数writeDat()的内容。

#include<stdio.h>

#include<string.h>

#include<conio.h>

charxx[50][80];

intmaxline=0;/*文章的总行数*/

intReadDat(void);

voidWriteDat(void);

voidConvertCharA(void)

{inti,j;

for(i=0;i<maxline;i++)

{for(j=0;j<strlen(xx[i]);j++)

if(xx[i]UJ==,z*)xx[i]UJ=fa,;

elseif(xx[i][j]>='a'&&xx[i]xx[i][j]+=1;

voidmain()

(

clrscr();

if(ReadDat()){

printf("数据文件IN.DAT不能打开!\n\007n);

return;

)

ConvertCharA();

WriteDat();

}

intReadDat(void)

(

FILE*fp;

inti=0;

char*p;

if((fp=fopen(,,IN.DAT,,;'ru))==NULL)return1;

while(fgets(xx[i],80,fp)!=NULL){

p=strchr(xx[ij,,\n,);

if(p)*p=O;

i++;

)

maxline=i;

fclose(fp);

return0;

)

voidWriteDat(void)

(

FILE*fp;

inti;

clrscr();

fp=fopen(',OUTl.DAT',;,w");

for(i=0;i<maxline;i++){

printf("%s\n”,xx[i]);

fprintf(fp,',%s\n,',xx[i]);

fclose(fp);

☆题目11(字符串字母移位题)

程序progl.c的功能是:把s字符串中的所有字母改写成该字母的下一个字母,字母z改写

成字母a。要求大写字母仍为大写字母,小写字母仍为小写字母,其它字符不做改变。

请考生编写函数chg(char*s)实现程序要求,最后调用函数readwriteDAT()把结果输出到文

件beLout中。

例如:s字符串中原有的内容为:Mn.l23Zxy,则调用该函数后,结果为:No.I23Ayz。

注意:部分源程序存在文件progl.c文件中。

请勿改动主函数main()和输出数据函数readwriteDAT。的内容。

#include<conio.h>

#include<string.h>

#include<stdio.h>

#include<ctype.h>

#defineN81

voidreadwriteDAT();

voidchg(char*s)

{intI;

for(I=0;I<strlen(s);I++)

if(s[i]==,z,lls[i]==,Z,)s[i]-=25;

elseif(s[i]>='a,&&s[i]<='y,lls[i]>='A,&&s[i]<=,Y,)s[i]+=l;

)

main()

(

chara[NJ;

clrscr();

printf(nEnterastring:");gets(a);

printf("Theoriginalstringis:");puts(a);

chg(a);

printf(nThestringaftermodified:");

puts(a);

readwriteDAT();

)

voidreadwriteDAT()

(

inti;

chara[N];

FILE*rf,*wf;

rf=fopen(nbcl.inn,nrn);

wf=fopen(Hbcl.outn,Hwn);

for(i=0;i<50;i++){

fscanf(rf,"%s",a);

chg(a);

fprintf(wf,u%s\nn,a);

)

fclose(rf);

fclose(wf);

)

★☆题目12(结构体运算题题)

已知在文件IN.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型

4位),产品名称me(字符型10位),单价dj(整型),数量si(整型),金额je(长整型)五部分组

成。其中:金额=单价*数量计算得出。函数ReadDat。是读取这100个销售记录并存入结构

数组sell中。请编制函数SortDat(),其功能要求:

按产品名称从小到大进行排列,若产品名称相等,则按金额从小到大进行排列,最终排列结

果仍存入结构数组sell中,最后调用函数WriteDat()把结果输出到文件OUT5.DAT中。

部分源程序存在文件progl.c中。

请勿改动主函数main。、读数据函数ReadDat。和输出数据函数WriteDat()的内容。

#include<stdio.h>

#include<mem.h>

#include<string.h>

#include<conio.h>

#include<stdlib.h>

#defineMAX100

typedefstruct{

chardm[5];/*产品代码*/

char产品名称*/

intdj;/*单价*/

intsi;/*数量*/

longje;/*金额*/

}PRO;

PROsell[MAXl;

voidReadDat();

voidWriteDat();

voidSortDat()

{inti,j;

PROxy;

for(i=0;i<99;i++)

for(j=i+l;j<100;j++)

if(strcmp(sell[i].mc,sell[j].mc)>Ollstrcmp(sell[i].mc,sell[j].mc)==O&&sell[i].je>sell[j].je)

{xy=sell[i];sell[i]=sell[j];sell[j]=xy;}

voidmain()

(

memset(sell,0,sizeof(sell));

ReadDat();

SortDat();

WriteDat();

)

voidReadDat()

(

HLE*fp;

charstr[8O],ch[ll];

inti;

fp=fopen(1,IN.DAT";,rn);

for(i=0;i<100;i++){

fgets(str,8O,fp);

memcpy(sell[i].dm,str,4);

memcpy(sell[i].mc,str+4,l0);

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()

(

FILE*fp;

inti;

fp=fopen("OUT5.DAT”,W);

for(i=0;i<100;i++){

printf(H%s%s%4d%5d%5d\n",sellfi].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.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型

4位),产品名称me(字符型10位),单价dj(整型),数量si(整型),金额je(长整型)五部分组

成。其中:金额=单价*数量计算得出。函数ReadDatO是读取这100个销售记录并存入结构

数组sell中。请编制函数SorlDat。,其功能

要求:按产品代码从小到大进行排列,若产品代码相等,则按金额从大到小进行排列,最终

排列结果仍存入结构数组sell中,最后调用函数WriteDat。把结果输出到文件OUT9.DAT中。

部分源程序存在文件prog1.c中。

请勿改动主函数main。、读数据函数ReadDatO和输出数据函数WrileDat。的内容。

#include<stdio.h>

#include<mem.h>

#include<string.h>

#include<conio.h>

#include<stdlib.h>

#defineMAX100

typedefstruct{

chardm[5];/*产品代码*/

char产品名称*/

intdj;/*单价

intsi;/*数量*/

longje;/*金额*/

}PRO;

PROsell[MAX];

voidReadDatO;

voidWriteDat();

voidSortDat()

{inti,j;

PROxy;

for(i=0;i<99;i++)

for(j=i+l;j<l00;j++)

if(strcmp(sell[i].dm,sell[j].dm)>Ollstrcmp(sell[i].dm,sell[j].dm)==O&&sell[i].je<sell[j].je)

{xy=sell[i];sell[i]=sell[j];sell[j]=xy;}

)

voidmain()

(

memset(sell,0,sizeof(sell));

ReadDatO;

SoilDat();

WriteDat();

voidReadDat()

(

FILE*fp;

charstr[8O],ch[l1];

inti;

fp=fopenC,IN.DATn;,rn);

for(i=0;i<100;i++){

fgets(str,8O,fp);

memcpy(sellfi].dm,str,4);

memcpy(sell[i].mc,str+4,10);

memcpy(ch,str+l4,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()

(

FILE*fp;

inti;

fp=fopen(',OUT9.DATn,uwn);

for(i=0;i<100;i++){

printf('1%s%s%4d%5d%5d\n",sell[i].dm,sell[i].mc,sell[i].dj,sell[i].sl,sell[i].je);

fprintf(fp,M%s%s%4d%5d%5d\n",sellliJ.dm,sell[iJ.mc,sellLiJ.dj,sellLiJ.sl,sell[iJ.je);

)

fclose(fp);

★☆题目14(整数统计排序题)

已知数据文件IN.DAT中存有200个四位数,并已调用读函数readDat。把这些数存入数组a

中,请考生编制一函数jsVal(),其功能是:依次从数组a中取出一个四位数,如果该四位数

连续大于该四位数以后的五个数且该数是奇数(该四位数以后不满五个数,则不统计),则

统计出满足此条件的个数ent并把这些四位数按从小到大的顺序存入数组b中,最后调用写

函数writeDat()把结果ent以及数组b中符合条件的四位数输出到OUT.DAT文件中。

注意:部分源程序存在文件progl.c中。

程序中已定义数组:a[200],b[200],已定义变量:ent

请勿改动数据文件IN.DAT中的任何数据、主函数main()、读函数readDat。和写函数writeDat()

的内容。

#include<stdio.h>

#defineMAX200

inta[MAX],b[MAX],cnt=0;

voidjsValO

{inti,j,flag;

for(i=0;i<MAX-5;i++)

{for(j=i+1;j<=i+5;j++)

if(a[i]>a[j]&&a[i]%2)flag=l;

else{flag=O;break;}

if(flag==l)b[cnt++]=a[i];

)

for(i=0;i<cnt-l;i++)

fbr(j=i+l;j<cnt;j++)

if(b[i]>b[j]){flag=b[i];b[i]=b|j];b[j]=flag;}

)

voidreadDat()

(

inti;

FILE*fp;

fp=fopen(nin.dat","r");

for(i=0;i<MAX;i++)fscanf(fp,n%d';&a[i]);

fclose(fp);

)

voidmain()

(

inti;

readDat();

jsVal();

printf("满足条件的数二%d\n”,ent);

for(i=0;i<ent;i++)printf(M%d",b[i]);

printf(“\n");

writeDat();

)

writeDat()

(

FILE*fp;

inti;

fp=fopen("out.dat","wu);

fprintf(fp,n%d\n",ent);

for(i=0;i<ent;i++)fprintf(fp,H%d\nM,b[i]);

fclose(fp);

★题目15(整数各位数字运算排序题)

已知数据文件IN.DAT中存有200个四位数,并已调用读函数readDat。把这些数存入数组a

中,请考生编制--函数jsVal(),其功能是:若•个四位数的千位数字上的值小于等于百位数

字上的值,百位数字上的值小于等于十位数字上的值,以及十位数字上的值小于等于个位数

字上的值,并且原四位数是偶数,则统计出满足此条件的个数ent并把这些四位数按从小到

大的顺序存入数组b中,最后调用写函数writeDat()把结果ent以及数组b中符合条件的四

位数输出到OUT.DAT文件中。

注意:部分源程序存在文件progl.c中。

程序中已定义数组:a[200],b[200],已定义变量:ent

请勿改动数据文件IN.DAT中的任何数据、主函数main。、读函数readDat。和写函数writeDat()

的内容。

#include<stdio.h>

#defineMAX200

inta[MAX],b[MAX],cnt=0;

voidjsValO

{inti,j;

intqw,bw,sw,gw;

for(i=0;i<MAX;i++)

{qw=a[i]/l000;bw=a[i]%1000/100;

sw=a[ij%100/10;gw=a[ij%l0;

if((qw<=bw)&&(bw<=sw)&&(sw<=gw)&&(a[i]%2==0))b[cnt++]=a[i];

)

for(i=0;i<cnt-1;i++)

fbr(j=i+l;j<cnt;j++)

if(b[i]>b[j]){qw=b[i];b[i]=bQ];b|j]=qw;}

)

voidreadDat()

(

inti;

FILE*fp;

fp=fopen(',in.daf,,Hr");

for(i=0;i<MAX;i++)fscanf(fp,”%d”,&a[i]);

fclose(fp);

voidmain()

inti;

readDat();

jsVal();

printf("满足条件的数二%d\n”,ent);

for(i=0;i<ent;i++)printf(n%d",b[i]);

printf(n\nn);

writeDat();

)

writeDat()

(

FILE*fp;

inti;

fp=fopen(nout.datn,"wu);

fprintf(fp,H%d\n",ent);

for(i=0;i<ent;i++)fprintf(母,"%d\n",b[i]);

fclose(fp);

)

★☆题目16(字符替换题)

函数ReadDat()实现从文件IN.DAT中读取一篇英文文章存入到字符串数组xx中,请编制函

数StrCharJR(),其函数的功能是:以行为单位把字符串中所有字符的ASCH值右移4位,

然后把右移后的字符ASCII值再加上原字符的ASCII值,得到新的字符仍存入原字符串对

应的位置上。最后把已处理的字符串仍按行重新存入字符串数组xx中,最后调用函数

writeDat。把结果xx输出到文件OUT8.DAT中。

原始数据文件存放的格式是:每行的宽度均小于80个字符,含标点符号和空格。

部分源程序存在文件progl.c中。

请勿改动主函数main。、读数据函数ReadDat。和输出数据函数writeDat()的内容。

#include<stdio.h>

#include<string.h>

#include<conio.h>

charxx[50][80];

intmaxline=0;/*文章的总行数*/

intReadDat(void);

voidWriteDat(void);

voidStrCharJR()

{intij;

for(i=0;i<maxline;i++)

for(j=0;j<strlen(xx[i]);j++)

xx[i][j]+=(xx[i][j]»4);

)

voidmain()

(

clrscr();

if(ReadDat()){

printf("数据文件IN.DAT不能打开!\n\007n);

return;

)

StrCharJR();

WriteDat();

}

intReadDat(void)

(

FILE*fp;

inti=0;

char*p;

if((fp=fopen(,,IN.DAT,,;'ru))==NULL)return1;

while(fgets(xx[i],80,fp)!=NULL){

p=strchr(xx[ij,,\n,);

if(p)*p=O;

i++;

)

maxline=i;

fclose(fp);

return0;

)

voidWriteDat(void)

(

FILE*fp;

inti;

clrscr();

fp=fopen(',OUT8.DAT',,uw,');

for(i=0;i<maxline;i++){

printf(M%s\nn,xx[iJ);

fprintf(fp,"%s\nH,xx[i]);

)

fclose(fp);

☆题目17(亲朋字符替换题)

函数READDAT()实现从文件IN.DAT中读取一篇英文文章存入到字符串数组XX中;请编

制函数CHA(),其函数功能是:以行为单位把字符串中的第一个字符的ASCH值加第二个字符

的ASCII值,得到第•个亲朋字符,第二个字符的ASCII值加第三个字符的ASCII值,得

到第二个新字符,依此类推一直处理到最后第二个字符,最后一个字符的ASCII值加原第

一个字符的ASCII值,得到最后一个新的字符,得到的新字符分别存放在原字符串对应的

位置上。最后把L1处理的字符串逆转后按行重新存入字符串数组XX中,最后调用函数

WRITEDAT。把结果XX输出到文件OUT9.DAT中.原始数据文件存放的格式是:每行的宽度

均小于80个字符,含标点符号和空格.

注意:部分源程序已给出。

请勿改动主函数main()、读数据函数ReadDat。和输出数据函数writeDat。的内容。

#include<stdio.h>

#include<string.h>

#include<conio.h>

charxx[50][80];

intmaxline=0;1*文章的总行数*/

intReadDat(void);

voidWriteDat(void);

voidChA(void)

{inti,j;

charch;

for(i=0;i<maxline;i++)

{ch=xx[i][0];

for(j=0;j<strlen(xx[i])-1;j++)

xx[i][j]+=xx[i][j+l];

xx[iJlstrlen(xx[i])-l]+=ch;

strrev(xx[i]);

voidmain()

(

clrscr();

if(ReadDat()){

printf("数据文件IN.DAT不能打开!\n'007”);

return;

}

ChA();

WriteDatO;

intReadDat(void)

FILE*fp;

inti=0;

char*p;

if((fp=fopen(nIN.DATH,"r1'))==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)

(

HLE*fp;

inti;

clrscr();

fp=fopen("OUT9.DAT“,“w”);

for(i=0;i<maxline;i++){

printf(M%s\nn,xx[i]);

fprintf(fp,"%s\nM,xx[i]);

)

fclose(fp);

)

☆题目18

函数ReadDat()实现从文件ENG.IN中读取一篇英文文章,存入到字符串数组xx中;请编制

函数encryptChar(),按给定的替代关系对数组xx中的所有字符进行替代,仍存入数组xx的

对应的位置上,最后调用函数WrileDat。把结果xx输出到文件PS10.DAT中。

替代关系:f(p)=p*llmod256(p是数组中某一个字符的ASCII值,f(p)是计算后新字符的

ASCII值),如果原字符的ASCII值是偶数或计算后f(p)值小于等于32,则该字符不变,否

则将f(p)所对应的字符进行替代。

部分源程序存在文件progl.c中。原始数据文件存放的格式是:每行的宽度均小于80个字符。

请勿改动主函数main。、读数据函数ReadDat。和输出数据函数WriteDat。的内容。

#include<stdio.h>

#include<string.h>

#include<conio.h>

#include<ctype.h>

unsignedcharxx[50][80];

inimaxline=O;/*文章的总行数*/

iniReadDat(void);

voidWriteDat(void);

voidencryptChar()

{inti,j;

for(i=0;i<maxline;i++)

for(j=0;j<strlen(xx[i]);j++)

if(xx[il[j]*11%256<=32llxx[i][j]%2==0)continue;

elsexx[i][j]=xx[i][j]*ll%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=O;

i++;

maxline=i;

fclose(fp);

return0;

voidWriteDat(void)

(

FILE*fp;

inti;

fp=fopen("psl0.dat","w");

for(i=0;i<maxline;i++){

printf(n%s\n",xx[i]);

fprintf(fp,H%s\nn,xx[i]);

)

fclose(fp);

)

☆题目19(单词个数统计题)

编写一个函数findStr(char*str,char*substr),该函数统1个长度为2的子字符串在另一个

字符串中出现的次数。例如,假定输入的字符串为"asdasasdfgasdaszx67asdmklo",子字

符串为“as”,函数返回值是6。

函数ReadWrite。实现从文件in.dat中读取两个字符串,并调用函数findStr(),最后把结果输

出到文件out.dat中。

注意:部分源程序存在文件progl.c中。

请勿改动主函数main()和其它函数中的任何内容,仅在函数findStr。的花括号中填入你编写

的若干语句。

#include<stdio.h>

#include<string.h>

#include<conio.h>

intfindStr(char*str,char*substr)

{inti,j,lenl,len2,cnt=0,flag;

lenl=strlen(str);

len2=strlen(substr);

for(i=0;i<lenl;i++)

{for(j=0;j<len2;j++)

if(str[i+jl==substr[j])flag=1;

else{flag=O;break;}

if(flag==l)cnt++;

)

returnent;

)

main()

charstr[81J,substr[3J;

intn;

clrscr();

printf("输入原字符串巧;

gets(str);

printf("输入子字符串

gets(substr);

puts(str);

puts(substr);

n=findStr(str,substr);

printf("n=%d\n",n);

ReadWrite();

)

ReadWrite()

(

charstr[81],substr[3],ch;

intn,len,i=0;

FILE*rf,*wf;

rf=fopen(Hin.datH,"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'IIch==Oxla)substr[lenj=0;

n=findStr(str,substr);

fprintf(wf,u%d\n",n);

i++;

)

fclose(rf);

fclose(wf);

}

★题目20(Fibonacci数列题)

编写函数jsValue,它的功能是:求Fibonacci数列中大于t的最小的一个数,结果山函数返

回。其中Fibonacci数列F(n)的定义为:

F(0)=0,F(l)=l

F(n)=F(n-l)+F(n-2)

最后调用函数writeDat。读

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论