1)可以选用哪种类型表征116.558这样一个数据?
Float
- 请问short* a= new short[10]; sizeof(a)的大小是多少?short b[10]; sizeof(b)大小又是多少?为什么?若想获取b数组能够容纳数据的个数,可以采用什么方法?
Sizeof(a)=8,sizeof(b)=20,a是指针,大小8个字节,b是数组,大小为容量乘以类型的长度=2*10,求容量可以shzeof(b)/数据类型的长度
3)在某环境下,执行如下语句后,无法得到1.5的正常结果,请问应如何修改。
float a = 3/2;
改为3.0/2或者3/2.0
4)程序希望实现a计算得到某一数据后自动退出的功能,请指出下面程序可能存在的风险。
void main()
{
float a = 0;
while (true)
{
...
一系列对a的运算;
if (a == 0.000123)
{
break;
}
}
return;
}
Float不是精确的类型,比较不一定准确,可以通过科学计数法进行比较,while循环可能一直循环,无法退出
5)请指出以下程序中的错误。
void main()
{
int a[10] = { 0 };
for (int i = 1; i <= 10; i++)
{
a[i] = i;
printf("%f\n", a[i]);
}
return;
}
超出数组的边界了,i表示的是数组的下标,是从0开始计数的,最高只有9.可以把i定义为0,并把范围修改为小于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定义为无符号数,范围为0到2^32-1,无法正常和有符号数比较。可以将a定义为int,或者在循环里转化为int。