实验一参考答案.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
实验一参考答案

实验一 参考答案 1、数据类型、运算符和表达式的应用 (1)整型数据的溢出(建立程序文件名为sy1-1.c) # include stdio.h void main() { short int a,b; a=32767; b=a+1; printf(a=%d,b=%d\n,a,b); } 程序运行结果:a=32767,b=-32768 原因:32767是short int型数据的最大值,其二进制为(0111111111111111),在其上加1后产生溢出,变成-32768的补码,其二进制为(1000000000000000)。整数在内存中以二进制补码形式存放,运算时符号位也要参与运算。结论:使用整型数据应注意其表示范围,避免产生溢出。 (2)浮点型数据的舍入误差(建立程序文件名为sy1-2.c) # include stdio.h void main() { float a,b; a=123456.789e5; b=a+20; printf(a=%f\tb=%f\n,a,b); } 程序运行结果:a=12345678848.000000 b=12345678868.000000 原因:理论分析a变量的值为12345678900,b的值经计算应为12345678920,结果输出的a和b的值都不对,原因是float型数据的有效数字位数为7位,后几位数字都是不准确的。结论:应当避免将一个很大的数和一个很小的数直接相加或相减,否则会“丢失”较小的数。 (3)字符型数据和整型数据的混合使用(建立程序文件名为sy1-3.c) # include stdio.h void main() { char c1,c2; c1=65; c2=66; printf(%c %c\n,c1,c2); } 程序运行结果:A B 原因:c1,c2两个变量的类型为char型,在内存中分配1B的存储空间用于存放字符的ASCII码二进制,其存放的数据范围为0~255。所以c1=65,即是字符‘A’的ASCII十制制值,c2=66即是字符‘B’的ASCII十进制值,%c是字符格式输出,即得A B。 扩展思考: 在上面程序的printf语句后增加语句“printf(%d %d\n,c1,c2);”,程序的运行结果是什么? 结果:A B 65 66 在上面程序的printf语句后增加语句“printf(%d %d\n,c1+32,c2+32);”,程序的运行结果是什么? 结果:A B 97 98 若将“char c1,c2;”改为“int c1,c2;”,程序的运行结果是什么?为什么? 结果:A B 因为在可输出的字符范围内(0~255),用整型和用字符型作用相同。 若将“c1=65; c2=66;”改为“c1=’A’; c2=’B’;”, 程序的运行结果是什么?为什么? 结果:A B 因为字符型数据在计算时必然转换为整型,即其ASCII码值计算。 若将“c1=65; c2=66;”改为“c1=A; c2=B;”,结果会怎么样? 结果:语法错误 因为字符变量只能存一个字符的ASCII码,不能存放字符串。 若将“c1=65; c2=66;”改为“c1=321; c2=322;”, 程序的运行结果是什么?为什么? 结果:A B 因为大于255的整数存放在1B空间的字符型变量中,只能存放其%256后的数据,321%256=65,322%256=66,其结果等价。 (4)算术表达式的求值(建立程序文件名为sy1-4.c) # include stdio.h void main() { int a,b; float x,y,r,s; a=7; x=2.5; y=4.7; r=x+a%3*(int)(x+y)%2/4; a=2; b=3; x=3.5; y=2.5; s=(float)(a+b)/2+(int)x%(int)y; printf(r=%.2f s=%.2f\n,r,s); } 结果:r=2.50 s=3.50 原因:r=2.5+7%3*(int)(2.5+4.7)%2/4 s=(float)(2+3)/2+(int)3.5%(int)2.5 =2.5+1*(int)(7.2)%2/4 =(float)5/2+3%2 =2.5+1*7%2/4 =2.5+1 =2.5+7%2/4

文档评论(0)

kabudou + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档