- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
函数Rdata()实现从文件IN.dat中读取一篇英文文章,存入到字符串数组string中,
请编写函数CharRight(),其功能是:以行为单位把字符串中的最后一个字符的ASCII值
右移4位后加倒数第二个字符的ASCII值,得到最后一个新的字符;倒数第二个字符的
ASCII值右移4位后加倒数第三个字符的ASCII值,得到倒数第二个新的字符;依此类推,
一直处理到第二个字符;第一个字符的ASCII值加原最后一个字符的ASCII值,得到第一
个新的字符。得到的新字符分别存放在原字符串对应的位置上,最后已处理的字符串仍按行
重新存入字符串数组string中。最后调用函数Wdata(),把结果string输出到文件
OUT.dat中。
原始数据文件存放的格式是:每行的宽度均小于80个字符(含标点符号和空格)。
注意:部分源程序已经给出。请勿改动主函数main()、读函数Rdata()和写函数
Wdata()的内容。
#include stdio.h #include string.h #include conio.h
char string[50][80];
int maxline = 0; /* 文章的总行数 */
int Rdata(void);
void Wdata(void);
void CharRight(void){}
void main()
{ if (Rdata())
{ printf(数据文件IN.dat不能打开!\n\007);
return;
}
CharRight();
Wdata();
}
int Rdata(void)
{ FILE *fp;
1
int i = 0;
char *p;
if ((fp = fopen(IN.dat, r)) == NULL)
return1;
while (fgets(string[i], 80, fp) != NULL)
{ p = strchr(string[i], \n);
if (p)
*p = 0;
i++;
}
maxline = i;
fclose(fp);
return 0;
}
void Wdata(void)
{ FILE *fp;
int i;
fp = fopen(OUT.dat, w);
for (i=0; imaxline;i++)
{ printf(%s\n, string[i]);
fprintf(fp, %s\n, string[i]);
}
fclose(fp);
}
2
试题答案及详解
【审题分析】分析题目可知,本题只要实现CharRight()函数的功能即可。CharRight()
函数要实现的功能是:按“将字符的ASCII值右移4位并加上该字符前面的一个字符的
ASCII值等到新的字符,然后存在原位”的替代关系,将字符串数组string中的字符全部替
换。因此解答本题的关键在于读取字符串数组中的字符,然后转换成ASCII码值,最后进
行替换运算。
【解题思路】这里我们通过for循环语句来实现读取字符串数组中的所有字符。当自变
量i从0递增到maxline时,就完成了对一篇文章每一行的扫描。对一行的字符串数组,
首先利用字符串函数strlen求出字符串数组string[i]的长度输给变量strl,把字符串中的
最后一个字符赋给ch;然后在for循环语句中当自变量j从strl-1递减到0时,对每一个
字符的ASCII值右移4位,右移4位的字符与其前一个字符相加,两者的和仍然存入字符
串数组元素string[i][j]中;最后替
您可能关注的文档
最近下载
- 2025年抖音本地生活服务业务深度分析报告 .pdf VIP
- 广西壮族自治区资源县农业局公务员招录事业单位招聘考试录用96人大全(含答案).docx VIP
- 清水河储能电站施工方案.doc VIP
- 2025至2030年中国美甲产业竞争现状及发展前景预测报告.docx
- 《新媒体营销》教学大纲.docx VIP
- 幼儿园小学生姓名卡片姓名贴纸.docx VIP
- 郑州市第四十七中学新初一分班(摸底)语文模拟试题(5套带答案).doc VIP
- 《边城》ppt.ppt VIP
- 2024凉山州专业技术人员继续教育公需科目-提升常态化监管水平,大力发展数字经济,支持平台经济发展试题及满分答案.docx VIP
- 口腔根尖周炎病例分析.pptx VIP
文档评论(0)