函数ReadDat()的功能是实现从文件ENG62.IN中读取一篇英文文章,存入到字符串数组xx中。请编制函数e
函数ReadDat()的功能是实现从文件ENG62.IN中读取一篇英文文章,存入到字符串数组xx中。请编制函数encryChar(),按给定的替代关系对数组xx中所有字符进行替代,仍存入数组xx的对应的位置上,最后调用函数WriteDat()把结果xx输出到文件PS62.DAT中。
替代关系:f(p)=p*13mod256(p是数组xx中某一个字符的ASCII值,f(p)是计算后新字符的ASCII值),如果计算后f(p)的值小于等于32或其ASCH值是偶数,则该字符不变,否则将f(p)所对应的字符进行替代。
注意:部分源程序已给出。
原始数据文件的存放格式是每行的宽度均小于80个字符。
请勿改动主函数main()、读函数ReadDat()和写函数WriteDat()的内容。
试题程序:
include<conio.h>
include<stdio.h>
include<string.h>
include<ctype.h>
unsigned char xx[50] [80];
int maxline=0;
int ReadDat(void);
void WriteDat(void);
void encryChar()
{
}
void main ()
{
clrscr();
if (ReadDat ( ))
{
printf ("数据文件ENG62.IN不能打开!\n\007");
return;
}
encryChar();
WriteDat();
}
int ReadDat(void)
{
FILE *fp;
int i=0;
unsigned char *p;
if((fp=fopen("ENG62.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()
{
FILE *fp;
int i;
fp= fopen("ps62.dat","w");
for(i=0;i<maxline;i++)
{
printf("%s\n",xx[i]);
fprintf(fp,"%s\n",xx[i]);
}
fclose(fp);
}
void encryChar() { int i; char*pf; for(i=0;imaxline;i++) { pf=xx[i]; /*指针pf指向该行的首地址*/ while(*pf!=0) { if(((*pf*13%256)%2==0) || (*pf*13%256=32)) /*如果计算后的值小于等于32或其ASCII值是偶数*/ { pf++; /*则该字符不变,去取下一个字符*/ continue; /*退出此次循环*/ } *pf=*pf*13%256; /*否则将新字符替代原字符*/ pf++; /*去取下一个字符*/ } } } 解析:本题考查的知识点如下:
(1)字符对应的ASCII码。
(2)判断结构中多个条件的“或”运算。
(3)退出一次循环。
在C语言中,字符可参与任何整数运算。实际上,是字符的ASCII码参与了运算。所以可以直接用字符代入f(p)的关系式中求出替换字符。若f(p)≤32或其ASCII值是偶数,则该字符不变。两个条件满足一个即可,所以这两个条件之间用“或”运算。若字符不变,则可不必计算替换字符,使用continue跳出本次循环,进入下一次循环的条件判断中。因为这里不是直接退出本层循环结构,所以不能使用break语句。
对于非零自然数M和N,规定符号&的含义是:M&N=2*M*N分之A*M+N(A为一个确定的整数), 数学 2020-05-16 …
对于非0自然数M和N,规定符号“*”的含义是:M*N=A乘M+N除以2乘M乘N(A为一个确定的整数 数学 2020-05-16 …
试说明:对于任意自然数,代数式n(n+7)-[n(n-5)+6]的值能被6整除 数学 2020-05-16 …
用数学归纳法做证明:n的3次方加5倍的n是6的倍数 数学 2020-06-11 …
关于牛顿环(或者劈尖干涉)的问题.如果牛顿环浸没在折射率大于玻璃的液体中,还有半波损失吗?题目中遇 物理 2020-07-01 …
如果关于字母X的二次多项式-3x^2+mx+nx^2-x+3的值与x的取值无关,求代数式-m^2- 数学 2020-07-27 …
有关平方根的两道题1:若m,n满足3*根号m+5|n|(|是绝对值符号)=7,2*根号m-3|n| 数学 2020-08-03 …
概率论与数理统计的题目x1.x6和y1.y4分别是来自相互独立的正太总体N(1,5)和N(2,6)的 数学 2020-10-30 …
问个递归的问题,整数划分问题是将一个正整数n拆成一组数连加并等于n的形式,且这组数中的最大加数不大于 数学 2020-11-18 …
(2006•淮安三模)如图所示,是一个用折射率,n=1.6的透明介质做成的三棱柱的横截面图,其中∠A 物理 2020-12-18 …