资源描述
2023年4月三级网络技术上机考试题
1.已知在文献IN.DAT中存有100个产品销售记录,每个产品销售记录由产品代码dm(字符型4位),产品名称mc(字符型10位),单价dj(整型),数量sl(整型),金额je(长整型)四部分组成。其中:金额=单价*数量计算得出。函数ReadDat()是读取这100个销售记录并存入结构数组sell中。请编制函数SortDat(),其功能规定:按产品代码从大到小进行排列,若产品代码相同,则按金额从大到小进行排列,最终排列结果仍存入结构数组sell中,最后调用函数WriteDat()把结果输出到文献OUT10.DAT中。,
部分源程序已给出。,
请勿改动主函数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(),
{,
},
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(void),
{,
FILE *fp;,
int i;,
fp=fopen("OUT10.DAT","w");,
for(i=0;i<100;i++){,
fprintf(fp,"%s %s %4d %5d %10Ld\n", sell[i].dm,sell[i].mc,sell[i].dj,sell[i].sl,sell[i].je);,
},
fclose(fp);,
}",
,
--------------------------------------------------------------------------------,
注:这时也是采用冒泡法进行排序。与前面的冒泡法在写法上有所不同请注意区分。,
void SortDat(),
{,
int i,j;,
PRO swap;,
for(i=0;i for(j=0;j { if(strcmp(sell[j].dm,sell[j+1].dm)<0) /*用函数strcmp判断两个字符串的大小*/,
{ swap=sell[j]; sell[j]=sell[j+1]; sell[j+1]=swap; },
if(strcmp(sell[j].dm,sell[j+1].dm)==0&&sell[j].je {,
swap=sell[j];,
sell[j]=sell[j+1];,
sell[j+1]=swap;,
} ,
},
},
若产品代码相同,则按金额从大到小进行排列没有体现!,
2.six+six+six=nine+nine的个数cnt及它们的和sum,s,i,n,e是0-9自然数,但s,n不能为0.,
如 984+984+984=1476+1476,,
我临时编的(也许算法不太好),
main(),
{,
int i,j,cnt=0;,
float sum=0;,
for(i=100;i<1000;i++),
for(j=1000;j<10000;j++),
{,
if(i+i+i==j+j),
{,
cnt++;,
sum=sum+i+j;,
printf("%d+%d+%d=%d+%d\n",i,i,i,j,j);,
},
},
printf("%d,%f",cnt,sum);,
},
参考这个:for(i=666;i<1000;i++),
if((i/10%10=(3*i/2)/100%10)&&((i*3/2)/1000=(i*3/2)/10%10),
{cnt++;,
sum+=(5/2)*i;,
},
,
3.函数ReadDat()实现从文献ENG.IN中读取一篇英文文章,存入到字符串数组xx中;请编制函数encryptChar(),按给定的替代关系对数组xx中的所有字符进行替代,仍存入数组xx的相应的位置上,最后调用函数WriteDat()把结果xx输出到文献PS4.DAT中。 ,
替代关系:f(p)=p*11 mod 256 (p是数组中某一个字符的ASCII值,f(p)是计算后新字符的ASCII值),假如计算后f(p)值小于等于32或f(p)相应的字符是大写字母,则该字符不变,否则将f(p)所相应的字符进行替代。 ,
部分源程序已给出。原始数据文献存放的格式是:每行的宽度均小于80个字符。 ,
请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。 ,
#include ,
#include ,
#include ,
#include ,
,
unsigned char xx[50][80]; ,
int maxline=0;/*文章的总行数*/ ,
,
int ReadDat(void) ,
void WriteDat(void) ,
,
void encryptChar() ,
{ ,
,
} ,
,
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(\"ps4.dat\",\"w\"); ,
for(i=0;i printf(\"%s\\n\",xx[i]); ,
fprintf(fp,\"%s\\n\",xx[i]); ,
} ,
fclose(fp); ,
} ,
,
,
-------------------------------------------------------------------------------- ,
,
注:下题1相似,只是它规定对f(p)进行判断。 ,
void encryptchar() ,
{ ,
int i; ,
char *pf; ,
for(i=0;i {pf=xx[i]; ,
while(*pf!=0) ,
{if(*pf*11%256>='A'&&*pf*11%256<='Z'||*pf*11%256<32) ,
{pf++;continue;} ,
*pf=*pf*11%256; ,
pf++; ,
} ,
} ,
} ,
,
,
,
void encryptChar() ,
{ ,
int i,j,t; ,
for(i=0;i { ,
for(j=0;j { ,
t=xx[i][j]*11%256; ,
if(t<=32 || t>='A' && t<='Z') continue; ,
xx[i][j]=t; ,
} ,
} ,
},
4.南开第一题,
函数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)所相应的字符进行替代。,
部分源程序已给出,原始数据文献存放的格式是:每行的宽度均小于80个字符。,
请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。 ,
#include,
#include,
#include,
#include,
unsigned char xx[50][80];,
int maxline=0;/*文章的总行数*/,
int ReadDat(void),
void WriteDat(void),
void encryptChar(),
{,
},
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);,
},
--------------------------------------------------------------------------------,
注:在ReadDat()函数中由于fgets()函数读入数据时没有读入字符串结束符'\0',因,
而用while()循环在xx数组每一行未尾将换行符'\n'替换成结束符'\0'。,
编写的函数如下:该函数的基本算法是——让字符指针pf指向每一行的开头然后逐个往,
后移动,在移动过程中按规定进行转换。*pf%2==0用于判断是否为偶数。if()条件语,
句用于控制不替代字符。,
的,
解法1:,
void encryptChar(),
{,
int i;,
char *pf;,
for(i=0;i {pf=xx[i]; /*每行字符个数*/ ,
while(*pf!=0),
{if(*pf%2==0||*pf*11%256<32),
{pf++;continue;} ,
*pf=*pf*11%256;,
pf++;,
},
},
},
展开阅读全文