




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
注忌:
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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年广东建设职业技术学院单招职业适应性测试题库含答案
- 2025年醚羧酸盐(AEC)项目合作计划书
- 2025年广西工业职业技术学院单招职业适应性测试题库新版
- 2025年湖南石油化工职业技术学院单招职业技能测试题库必考题
- 山东潍坊市2023-2024学年高二上学期期中考试补偿练地理试题(解析版)
- 山东省日照市2023-2024学年高二上学期期中考试地理试题(解析版)
- 湖南省T8联盟2023-2024学年高三上学期12月份模拟预测地理试题(解析版)
- 第6课 戊戌变法(教学设计)-2024-2025学年八年级历史上册素养提升教学设计(统编版)
- 15《超链接的插入》教学设计、教材分析与教学反思2024年滇人版初中信息技术七年级下册
- 肝的生理特性中医基础理论
- 浙江省金华市婺城区2024-2025学年九年级上学期期末数学试卷(含答案)
- Unit 4 A glimpse of the future 说课稿-2023-2024学年高二下学期英语外研版(2019)选择性必修第三册001
- 万达广场筹备期项目管理规范
- 乡村建设规划许可培训
- 加气站安全课件
- 北师大版二年级数学下册各单元测试卷
- GB/T 45037-2024粮油机械扒谷机
- 财务会计(对外经济贸易大学)知到智慧树章节测试课后答案2024年秋对外经济贸易大学
- 分布式计算平台设计与实现
- 团聚体与土壤有机质转化-洞察分析
- 护理总带教老师讲课
评论
0/150
提交评论