预览加载中,请您耐心等待几秒...
1/5
2/5
3/5
4/5
5/5

在线预览结束,喜欢就下载吧,查找使用更方便

如果您无法下载资料,请参考说明:

1、部分资料下载需要金币,请确保您的账户上有足够的金币

2、已购买过的文档,再次下载不重复扣费

3、资料包下载后请先用软件解压,在使用对应软件打开

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