3.22作业

文章讨论了数据类型如double和float的选择,内存大小的计算方法,浮点数除法精度问题,程序设计中的风险和错误,包括指针大小、数组元素个数获取、浮点数比较和循环条件的调整。
摘要由CSDN通过智能技术生成

1)可以选用哪种类型表征116.558这样一个数据?

char int short double float

答:double float

  1. 请问short* a= new short[10]; sizeof(a)的大小是多少?short b[10]; sizeof(b)大小又是多少?为什么?若想获取b数组能够容纳数据的个数,可以采用什么方法?

答:sizeof[a]=4是因为short* a是指针,应是指针的大小。Sizeof(b)=20是因为这是整个数组的大小,short占2个字节。方法sizeof(b)/sizeof(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;

}答:float对0的比较不准确应是a>=-1e-6 && a<=1e-6

while中的条件是ture会一直循环,a的结果会输出不准确

5)请指出以下程序中的错误。

void main()

{

int a[10] = { 0 };

for (int i = 1; i <= 10; i++)

{

a[i] = i;

printf("%f\n", a[i]);

}

return;

}答:int i=1是错的应改为int i=0

printf(%f\n,a[i])是错的应改为printf(%d\n,a[i])

6)以下程序想实现一个从-5开始的为期10次的循环,并输出i的值,但程序无法正常运行,请分析原因,并进行修改。

void main()

{

unsigned int a = 5;

for (int i = -5; i < a; i++)

{

printf("i=%d\n", i);

}

return;

}答:unsigend是无符号,循环条件i<a这个条件是错的不能两个整数比较的应改为i<9。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值