A-A+

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

2022-08-06 05:23:55 问答库 阅读 176 次

问题详情

函数ReadDat()实现从文件eng.in中读取一篇英文文章,存入到字符串数组xx中。请编制函数encryptChar(),按给定的替代关系对数组xx中的所有字符进行替代,仍存入数组xx的对应的位置上,最后调用函数WriteDat()把结果xx输出到文件ps10.dat中。
替代关系:f(p)=p*43 mod 256(p是数组中某一个字符的ASCII值,fO)是计算后新字符的ASCII值),如果原字符的ASCII值是偶数或计算后fb)值小于等于32,则该字符不变,否则将qp)所对应的字符进行替代。
部分源程序己给出,原始数据文件存放的格式是:每行的宽度均小于80个字符。
请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。
include<stdio.h>
include<string.h>
include<conio.h>
include<ctype.h>
unsigned char xx[50][80];
int maxline=0;/*文章的总行数*/
int ReadDat(void)
void WriteDat(void)
void encryptChar()
{
}
void main()
{
clrscr();
if(ReadDat()){
printf ("数据文件 ENG. IN 不能打开! n07");
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<maxline;i++){
printf("%sn",xx[i]);
fprintf(fp,"%sn",xx[i]);
}
fclose(fp);
}请帮忙给出正确答案和分析,谢谢!

参考答案

正确答案:void encryptChar(){/*字符替换过程中运算的中间结果可能超过256*//*因此采用整型存储中间结果*/int ijt;for(i=0;i<maxline;i++)/*遍历每一行*/{for(j=0;i<strlen(xx[i]);j++){/*用控型变量进行所有运算*/t=xx[i][j];t=t*43%256;/*判断替换条件*/if(t<=32 || xx[i][j]%2==0) continue;xx[i][j]=t;}}}
void encryptChar(){/*字符替换过程中,运算的中间结果可能超过256*//*因此采用整型存储中间结果*/int i,j,t;for(i=0;i<maxline;i++)/*遍历每一行*/{for(j=0;i<strlen(xx[i]);j++){/*用控型变量进行所有运算*/t=xx[i][j];t=t*43%256;/*判断替换条件*/if(t<=32 || xx[i][j]%2==0) continue;xx[i][j]=t;}}} 解析:关键点:
1.字符串读写。
2.由于fgets()函数读入数据时读入换行符'\n',因而需要在xx数组每一行末尾将换行符'\n'替换成结束符'\0'。本题中此步已经在ReadDat()函数中完成。
3.算法:让字符指针pf指向每一行的开头然后逐一往后移动,在移动过程中按要求进行转换。*pf%2=0用于判断是否为偶数。If()条件语句用于控制不替代字符。
4.中间变量的类型选择整型。

考点:数组,字符串