- 1、本文档共189页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 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)