1.可以选用哪种类型表征116.558这样一个数据?
double,float
2.请问short* a= new short[10]; sizeof(a)的大小是多少?short b[10]; sizeof(b)大小又是多少?为什么?若想获取b数组能够容纳数据的个数,可以采用什么方法?
4,20,short是两个字节,10*2=20,a是一个指针变量,指针变量的在32位操作系统中大小均为4,获取b数组容纳数据的个数可以用sizeof(b)/sizeof(0)
3.在某环境下,执行如下语句后,无法得到1.5的正常结果,请问应如何修改。float a = 3/2;
float a=3.0/2或者float a = (float)3/2
4.程序希望实现a计算得到某一数据后自动退出的功能,请指出下面程序可能存在的风险。
void main()
{
float a = 0;
while (true)
{
...
一系列对a的运算;
if (a == 0.000123)
{
break;
}
}
return;
}
a的数据类型是浮点类型,浮点数据类型的比较是不精确的,可以改为if(a-0.000123>=-1e-6&&a-0.000123<=1e-6)
5.请指出以下程序中的错误。
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开始,i的初始值为0,i的取值范围为i<10,a[i]的类型为int型输出时应该使用 %d
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进行比较时,i会被转换为一个无符号的整型,当i为负数时转换为无符号的整型时,i的值比a大。进入不了for循环
可以修改为: unsigned int a=5 --> int a=5;