c语言上机练习100题.doc

  1. 1、本文档共189页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
c语言上机练习100题

c语言上机练习100题 一、替换字符。(1、3、5、7、9、27、30、73、79、91、93、95、97、99) 二、字符串左右排序和比较。(2、4、6、12、26、29、71、72、74、84、90、96、98、100) 三、正整数排序求平均值(包括将数拆散、求最大最小值)。(8、31、33、35、37、39、42、 44、46、47、48、49、50、51、52、53、54、56、58、60、61、63、65、67、69、92、94、) 四、产品五个因素的比较排列,是结构体操作问题。(11、13、15、17、19、81、83、85、87、89 ) 五、素数。(14、22、28、51、80 ) 六、数字排序。(10、18、) 七、其他数学计算。(16、20、36、43、55、57、59、64、66、78、86、88 ) 八、数字或字符移位后的计算。(21、23、41、45、77 ) 九、学生成绩,结构体问题。(24、76 ) 十、字符串(单词)的倒置和删除。(25、75 ) 十一、选票问题。(32、68、70、82 ) 十二、出圈问题。(34 ) 十三、进制转换。(38、40、62 ) 1题 函数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()的内容。 #includestdio.h #includestring.h #includeconio.h #includectype.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不能打开!\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;imaxline;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;imaxline;i++) /*行循环*/ {pf=xx[i]; /*每行字符个数*/ while(*pf!=0) {if(*pf%2==0||*pf*11%25632) {pf++;continue;} *pf=*pf*11%256; pf++; } } } 解法2: void encryptChar() { int i,j,t; for(i=0;ima

文档评论(0)

zhuwenmeijiale + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

版权声明书
用户编号:7065136142000003

1亿VIP精品文档

相关文档