注意:正确实现本题中协议1的功能,可不作答其他题目。以下所有题目均基于32位系统,不考虑64位系统。
1)可以选用哪种类型表征116.558这样一个数据?
答:可以用double和 float;
2)在某环境下,执行如下语句后,无法得到1.5的正常结果,请问应如何修改。 float a = 3/2;
答:floata=(float)3/2 ; float=3.0/2
3)程序希望实现a计算得到某一数据后自动退出的功能,请指出下面程序可能存在的风险。
void main()
{
float a = 0;
while (true)
{
... 一系列对a的运算;
if (a == 0.000123)
{
break;
}
}
return;
}
答:float类型数据不能直接进行比较,可以用-123e-6<=a&&123e-6>=a进行比较
4)请指出以下程序中的错误。
void main()
{
int a[10] = { 0 };
for (int i = 1; i <= 10; i++)
{
a[i] = i;
printf("%f\n", a[i]);
}
return;
}
答:数组a中只能存储10个数据,且这个十个数据的角标编号为0、1、2、3、4、5、6、7、8、9,程序中for循环是从1开始赋值的,这个一个值赋给数组a溢出了。
5)以下程序想实现一个从-5开始的为期10次的循环,并输出i的值,但程序无法正常运行,请分析原因,并进行修改。
void main()
{
unsigned int a = 5;
for (int i = -5; i < a; i++)
{
printf("i=%d\n", i);
}
return;
}
答:a定义的类型是unsigned int,而for循环中i定义的类型的为int ,两个类型比较会强转为无符号整形,负数转为无符号值会非常大,导致for循环无法执行;改如下
```c
void main()
{
int a = 5;
for (int i = -5; i < a; i++)
{
printf("i=%d\n", i);
}
return;
}