1)可以选用哪种类型表征116.558这样一个数据?
char int short double float
可以使用double float
2)请问short* a= new short[10]; sizeof(a)的大小是多少?short b[10]; sizeof(b)大小又是多少?为什么?若想获取b数组能够容纳数据的个数,可以采用什么方法?
sizeof(a)的大小为2个字节,原因是是一个short型的指针,指向的是它的首位地址,而sizeof(b)的字节大小是2*10字节,是指所占空间容量大小。
可以使用sizeof(b)/b[0]来计算容纳个数大小
3)在某环境下,执行如下语句后,无法得到1.5的正常结果,请问应如何修改。
float a = 3/2;
修改结果为:float a = (float)3/2;
4)程序希望实现a计算得到某一数据后自动退出的功能,请指出下面程序可能存在的风险。
void main()
{
float a = 0;
while (true)
{
...
一系列对a的运算;
if (a == 0.000123)
{
break;
}
}
return;
}
由于在if语句中不能实现对浮点类型数据的精确对比,只能在一个范围进行比较,所以对a == 0.000123这个相等判断无法精确比较,可能a的值在一个范围内就会就执行if语句中的break语句,而a不一定会等于0.000123。
5)请指出以下程序中的错误。
void main()
{
int a[10] = { 0 };
for (int i = 1; i <= 10; i++)
{
a[i] = i;
printf("%f\n", a[i]);
}
return;
}
答:由于定义的是int类型的数组,所以在数组中是的值也应该是int类型,所以在printf打印函数打印时结果会以浮点类型输出,不能用%f来打印。
并且在for循环中数组的下标超限,在a[10]位置时,会出现数组越界,可能会出现段错误。
6)以下程序想实现一个从-5开始的为期10次的循环,并输出i的值,但程序无法正常运行,请分析原因,并进行修改。
void main()
{
unsigned int a = 5;
for (int i = -5; i < a; i++)
{
printf("i=%d\n", i);
}
return;
}
答:由于a定义时,是一个无符号的整型,i又是个有符号的整型,所以在for循环中比较时,有符号的-5的值就远大于无符号的5,所以循环就无法进行。
void main()
{
int a = 5;
for (int i = -5; i < a; i++)
{
printf("i=%d\n", i);
}
return;
}