网络技术上机考试专用_第1页
网络技术上机考试专用_第2页
网络技术上机考试专用_第3页
网络技术上机考试专用_第4页
网络技术上机考试专用_第5页
已阅读5页,还剩225页未读 继续免费阅读

下载本文档

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

文档简介

注忌:

1、题目标题号前用显示的是2005年4月份本人根据各大论坛考生H贵的题号集中而来,

题号前加“★”为2005年9月上机考试题,其中难免有题型相同而题号增加的现象,此类

标明,仅供参考。

2、每种题目,只用一种解题方法,加粗部分为解题答案,此种方法本人觉得容易理解,不

易出错,适合初学者。

3、特别说明:所有解法,本人均上机验证通过。

4、个别南开题如57、100题,题目与原书有所不同,是按实际考试的题目所来,并对今年

在实际上机中出现的考题,用红色部分表示实际上机题中的注明事项。

正式开始

☆题目1

请编写一个函数jsValue(intm,intk,intxx[]),该函数的功能是:将大于整数m且紧靠

m的k个素数存入数组xx传回。

最后调用函数writeDatO读取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,intk,intxx[])

{ints=0;

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

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

)

mainO

(

intm,n,xx[1000];

clrscr();

printfCAnPleaseentertwointegers/7);

scanf&m,&n);

num(m,n,xx);

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

printf(〃%d”,xx[m]);

printf(〃\n〃);

readwriteDat();

}

voidreadwriteDat()

!

intm,n,xx[1000],i;

FILE*rf,*wf;

rf=fopen(,zin.dat〃,〃r〃);

wf=fopen(,zout.dat〃,〃w〃);

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

fscanf(rf,,z%d%d〃,&m,&n);

num(m,n,xx);

for(m=0;m<n;m++)fprintf(wf,,z%d〃,xx[m]);

fprintf(wf,〃\n〃);

(

fclose(rf);

fclose(wf);

)

☆题目2

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

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

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

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

OUT.DAT文件中。

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

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

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

writeDat()的内容。

©include<stdio.h>

#defineMAX200

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

voidjsVal0

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

for(i=0;i<MAX;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<cnt-l;i++)

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

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

)

voidreadDat()

{

inti;

FILE*fp;

fp=fopen(〃in.dat〃,〃r〃);

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

fclose(fp);

}

voidmain()

I

inti;

readDat();

jsVal();

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

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

printf(〃\n〃)

writeDat();

writeDat()

!

FILE*fp;

inti;

fp=fopen(〃out.dat〃,〃w〃);

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

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

fclose(fp);

)

★题目3

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

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

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

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

用函数WriteDat()把结果xx输出到文件0UT5.DAT中。

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

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

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

#include<stdio.h>

#include<string.h>

#include<conio.h>

charxx[50][80];

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

intReadDat(void);

voidWriteDat(void);

voidStrOR(void)

{inti,righto,j,s,k;

chartem[80];

for(i=0;Kmaxline;i++)

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

{k=0;

memset(tem,0,80);

if(xx[i]

{righto二j;

for(s=righto+l;s<strlen(xx[ij);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(〃数据文件1n。人丁不能打开!\术007〃);

return;

)

StrORO;

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;

I

voidWriteDat(void)

FILE*fp;

inti;

clrscr();

fp=fopen(〃0UT5.DAT","w");

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

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

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

}

fclose(fp);

)

★题目4

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

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

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

调用函数writeDat()把结果xx输出到文件0UT6.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,叫strl;

charstr[80];

for(i=0;Kmaxline;i++)

{strl=strlen(xx[i]);

memset(str,0,80);

s=k=0;

for(j=strl-l;j>=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=l;m<=k;m++)

str[s++]=xx[i][j+m];

str[s]=,\0>;

strcpy(xx[i],str);)

)

voidmain()

(

clrscr();

if(ReadDat()){

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

return;

}

StrOL();

WriteDat();

)

intReadDat(void)

I

FILE*fp;

inti=0;

char*p;

if((fp=fop6n(〃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("0UT6.DAT","w");

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

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

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

)

fclose(fp);

}

*

☆题目5(整数排序题)

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

这200个数存放到数组aa中。请编制函数jsSortO,其函数的功能是:要求按每个数的后

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

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

文件out.dat中。

例:处理前60125099901270258088

处理后90126012702580885099

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

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

^include<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]%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];

)

voidmain()

I

readDat();

jsSort();

writeDat();

)

readDat()

I

FILE*in;

inti;

i•n=ir-open(/〃m•.diat,〃,〃r〃\;;

for(i=0;i<200;i++)fscanf(in,〃%d,;

fclose(in);

)

writeDat()

1

FILE*out;

inti;

clrscr();

out=fopen(,,out.dat〃,〃w〃);

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

printfC%d,z,bb[i]);

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

}

fclose(out);

}

☆题目6正整数排序

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

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

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

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

文件out.dat中。

例:处理前90125099601270258088

处理后50998088702560129012

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

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

#include<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]%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];

)

voidmain()

I

readDat();

jsSort();

writeDat();

system(,zpause,z);

}

readDat()

FILE*in;

inti;

in=ropen(in.dat,r;;

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

fclose(in);

)

writeDat()

I

FILE*out;

inti;

clrscr0;

out=fopen(,,out.dat〃,〃w〃);

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

printf(z,i=%d,%d\n/z,i+1,bb[i]);

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

}

fclose(out);

)

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

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

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

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

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

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

调用函数WriteDat()把结果输出到文件0UT6.DAT中。

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

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

^include<stdio.h>

#include<mem.h>

#include<string.h>

#include<conio.h>

#include<stdlib.h>

^defineMAX100

typedefstruct{

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

charme[11];/*产品名称*/

intdj;/*单价*/

intsi;/*数量*/

longje;/*金额*/

}PRO;

PROsell[MAX];

voidReadDat();

voidWriteDat();

voidSortDat()

{inti,j;

PROxy;

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

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

if(strcmp(sell[i].dm,selltj].dm)<0||strcmp(sell[i].dm,selltj].dm)==0&&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()

FILE*fp;

charstr[80],ch[ll];

inti;

fp=fopen(,zIN.DAT",;

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[ij.dj*sell[i].si;

)

fclose(fp);

}

voidWriteDat(void)

(

FILE*fp;

inti;

fp=fopen("0UT6.DAT","w");

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

printf(z/%s%s%4d%5d%5d\n?/,

sell[i].dm,sell[i].me,sell[i].dj,sell[i].si,sei1[i].je);

fprintf(fp,//%s%s%4d%5d%5d\nz/,

sell[i].dm,sell[i].me,sell[i].dj,sell[i].si,sell[i].je);

}

fclose(fp);

)

★题目8(字符替换题)

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

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

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

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

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

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

中。原始数据文件存放的格式是:每行的宽度均小于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;Kmaxline;i++)

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

if(xx[i][j]*ll%256<=32||xx[i][j]*ll%256>130)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=0;

i++;

I

maxline=i;

fclose(fp);

return0;

)

voidWriteDat(void)

I

FILE*fp;

inti;

fp=fopen(,zpsl.dat〃,〃w〃);

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

printf("版\n〃,xx[i]);

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

(

fclose(fp);

)

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

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

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

的结果仍按行重新存入字符串数组xx中,最后调用函数writeDatO把结果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][80];

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

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][j]<xx[i][k])

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

)

)

voidmain()

{

clrscr();

if(ReadDat()){

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

return;

}

SortCharD();

WriteDat();

)

intReadDat(void)

I

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;

fp=fopenC0UT2.DAT",〃w〃);

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

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

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

)

fclose(fp);

}

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

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

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

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

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

函数writeDat0把结果xx输出到文件0UT1.DAT中。

例:原文:Adb.Bcdza

abck.LLhj

结果:Aec.Bdeab

bcdl.LLik

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

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

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

ttinclude<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][j]=z)xx[i][j]=a;

elseif(xx[i][j]>=,a&&xx[i][j]<-yJ)xx[i][j]+=l;

voidmainO

clrscr();

if(ReadDat()){

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

return;

)

ConvertCharA();

WriteDat();

)

intReadDat(void)

(

FILE*fp;

inti=0;

char*p;

if((fp二fop6n(〃IN.DAT",〃r"))二二NULL)return1;

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

p=strchr(xx[i],>\nJ);

if(p)*p=0;

i++;

)

maxline=i;

fclose(fp);

return0;

}

voidWriteDat(void)

!

FILE*fp;

inti;

clrscr();

fp=fopen(,zOUT1.DAT","w");

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

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

,,,,

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

I

fclose(fp);

)

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

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

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

请考生编写函数chg(char*s)实现程序要求,最后调用函数「四小江"0口八丁()把结果输

出到文件bcl.out中。

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

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

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

#include<conio.h>

#include<string.h>

#include<stdio.h>

#include<ctype.h>

#defineN81

voidreadwriteDAT();

voidchg(char*s)

{intI;

for(1=0;Kstrlen(s);I++)

if(s[i]==z||s[i]='Z')s[i]-=25;

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

)

main()

{

chara[N];

clrscr();

printf(^Enterastring:〃);gets(a);

printf(,zTheoriginalstringis:〃);puts(a);

chg(a);

printf(,zThestringaftermodified:〃);

puts(a);

readwriteDAT();

}

voidreadwriteDATO

!

inti;

chara[N];

FILE*rf,*wf;

rf=fopen(〃bcl.in〃,〃r〃);

wf=fopen(〃bcl.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

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

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

构数组sell中。请编制函数SortDatO,其功能要求:

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

果仍存入结构数组sell中,最后调用函数WriteDatO把结果输出到文件0UT5.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];/*产品代码*/

charmc[ll];/*产品名称*/

intdj;/*单价*/

intsi;/*数量*/

longje;/*金额*/

}PRO;

PROsell[MAX];

voidReadDat();

voidWriteDat();

voidSortDat()

{inti,j;

PROxy;

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

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

if(strcmp(sell[i].me,sell[j].me)>01|strcmp(sell[i].me,sell[j].mc)==0&&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();

1

voidReadDat()

!

FILE*fp;

charstr[80],ch[l1];

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].me,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].si;

}

fclose(fp);

)

voidWriteDat()

(

FILE*fp;

inti;

fp=fopenC0UT5.DAT",,zw");

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

printf(,z%s%s%4d%5d%5d\n,z,sell[i].dm,sell[i].mc,sell[i].dj,sell[i].si,sell[

i].je);

fprintf(fp,,z%s%s%4d%5d%5d\n”,

sell[i].dm,sell[i].me,sell[i].dj,sell[i].si,sell[i].je);

}

fclose(fp);

题目13(结构体运算题)

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

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

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

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

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

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

中。

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

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

#include<stdio.h>

#include<mem.h>

#include<string.h>

#include<conio.h>

#include<stdlib.h>

#defineMAX100

typedefstruct(

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

charmc[ll];/*产品名称*/

intdj;/*单价*/

intsi;/*数量*/

longje;/*金额*/

}PRO;

PROsell[MAX];

voidReadDat();

voidWriteDat();

voidSortDat()

{inti,j;

PROxy;

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

for(j=i+l;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;}

)

voidmain()

(

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

ReadDat();

SortDat();

WriteDat();

)

voidReadDat()

FILE*fp;

charstr[80],ch[ll];

inti;

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

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

fgets(str,80,fp);

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

memcpy(sell[i].me,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].si;

)

fclose(fp);

voidWriteDat()

FILE*fp;

inti;

fp=fopen(z,0UT9.DAT",〃w");

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

printf("%s%s%4d%5d%5d\n”,

sell[i].dm,sell[i].me,sell[i].dj,sei1[i].si,sell[i].je);

fprintf(fp,"%s%s%4d%5d%5d\n”,

sell[i].dm,sell[i].me,sell[i].dj,sell[i].si,sei1[i].je);

)

fclose(fp);

}

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

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

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

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

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

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

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

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

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

writeDat()的内容。

#include<stdio.h>

ttdefineMAX200

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

voidjsVal0

{inti,j,flag;

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

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

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

else{flag=0;break;}

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

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

for(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(〃in.dat〃,〃r〃);

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

fclose(fp);

voidmain()

inti;

readDat();

jsValO;

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

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

printf(z,\n,z);

writeDat();

)

writeDat()

FILE*fp;

inti;

fp=fopen("out.dat〃,“w〃);

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

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

fclose(fp);

)

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

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

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

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

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

到大的顺序存入数组b中,最后调用写函数w「iteDat()把结果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;

voidjsVal()

{inti,j;

intqw,bw,sw,gw;

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

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

sw=a[i]%100/10;gw=a[i]%10;

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

)

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

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

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

)

voidreadDat()

I

inti;

FILE*fp;

fp=fopen(z,in.datz,,〃r〃);

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

fclose(fp);

)

voidmain()

I

inti;

readDat();

jsValO;

printf(〃满足条件的数或d\n",ent);

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

printfCW);

writeDat();

)

writeDat()

(

FILE*fp;

inti;

fp=fopen(/zout.datz,,〃w〃);

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

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

fclose(fp);

)

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

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

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

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

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

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

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

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

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

#include<stdio.h>

#include<string.h>

#include<conio.h>

charxx[50][80];

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

intReadDat(void);

voidWriteDat(void);

voidStrCharJR()

{inti,j;

for(i=0;Kmaxline;i++)

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

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

)

voidmain()

I

clrscr();

if(ReadDat()){

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

return;

I

StrCharJR0;

WriteDat();

}

intReadDat(void)

!

FILE*fp;

inti=0;

char*p;

if((fp=fopenClN.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)

I

FILE*fp;

inti;

clrscr();

fp二fopen("0UT8.DAT”,〃w〃);

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

printf,xx[i]);

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

}

fclose(fp);

}

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

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

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

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

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

符的ASCH值,得到最后一个新的字符,得到的新字符分别存放在原字符串对应的位置上。

最后把已处理的字符串逆转后按行重新存入字符串数组XX中,最后调用函数WRITEDATO把

结果XX输出到文件0UT9.DAT中.原始数据文件存放的格式是:每行的宽度均小于80个字符,

含标点符号和空格.

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

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

#include<stdio.h>

ftinclude<string.h>

#include<conio.h>

charxx[50][80];

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

intReadDat(void);

voidWriteDat(void);

voidChA(void)

{inti,j;

charch;

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

{ch=xx[i][0];

for(j=0;j<strlen(xxj++)

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

xx[i][strlen(xx[i])-1]+=ch;

strrev(xx[i]);

)

voidmain()

I

clrscr();

if(ReadDat()){

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

return;

}

ChA();

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++;

)

maxiine=i;

fclose(fp);

return0;

voidWriteDat(void)

(

FILE*fp;

inti;

clrscr();

fp=fopen("0UT9.DAT","w");

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

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

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

)

fclose(fp);

)

☆题目18

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

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

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

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

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

温馨提示

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

评论

0/150

提交评论