【2006年全国房价】2006年9月全国等级考试三级c语言上机题库(八)

试题集锦 2023-06-15 网络整理 可可

【shitiku.jxxyjl.com--试题集锦】

★☆题目8(无忧id 83 字符替换题)

函数readdat()实现从文件eng.in中读取一篇英文文章,存入到字符串数组xx中;请编制函数encryptchar(),按给定的替代关系对数组xx中的所有字符进行替代,仍存入数组xx的对应的位置上,最后调用函数writedat()把结果xx输出到文件ps1.dat中。
  替代关系:f(p)=p*11 mod 256(p是数组中某一个字符的ascii值,f(p)是计算后新字符的ascii值),如果计算后f(p)值小于等于32或大于130,则该字符不变,否则将f(p)所对应的字符进行替代。部分源程序存在文件prog1.c中。原始数据文件存放的格式是:每行的宽度均小于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()
{ int i,j;
for(i=0;i<maxline;i++)
for(j=0;j<strlen(xx[i]);j++)
if(xx[i][j]*11%256<=32||xx[i][j]*11%256>130) continue;
else xx[i][j]=xx[i][j]*11%256;
}

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("ps1.dat","w");
for(i=0;i<maxline;i++){
printf("%s\n",xx[i]);
fprintf(fp,"%s\n",xx[i]);
}
fclose(fp);
}
解法二:
void encryptchar()
{ int i,j,k;
for(i=0;i<maxline;i++)
for(j=0;j<strlen(xx[i]);j++)
{ k= xx[i][j]*11%256;
if(k<=32||k>130) continue;
else xx[i][j]=k;
}
}

解法三:
void encryptchar()
{ int i,j;
unsigned char ch;
for(i=0;i<maxline;i++)
for(j=0;j<strlen(xx[i]);j++)
{ ch=xx[i][j]*11%256;
if(ch<=32||ch>130) continue;
else xx[i][j]=ch;
}
}

解法四:
void encryptchar()
{ int i,j;
char *p;
for(i=0;i<maxline;i++)
for(j=0;j<strlen(xx[i]);j++)
{ p=xx[i][j]*11%256;
if(p<=32||p>130) continue;
else xx[i][j]=p;
}
}

解法五:
void encryptchar()
{ int i;
char *pf;
for(i=0;i<maxline;i++)
{ pf=xx[i];
while(*pf!=0)
if(*pf*11%256<=32||*pf*11%256>130) pf++;
else *pf++=*pf*11%256;
}
}

本文来源:https://shitiku.jxxyjl.com/shitijijin2/27209.html

Copyright @ 2011- 考试题库网 All Rights Reserved. 版权所有

免责声明 :本网站尊重并保护知识产权,根据《信息网络传播权保护条例》,如果我们转载的作品侵犯了您的权利,请在一个月内通知我们,我们会及时删除。

 站长统计