csapp2e 家庭作业 2.95

#include <stdio.h>
#include <limits.h>

typedef unsigned float_bits;
float_bits float_i2f(int i)
{
	unsigned u = (unsigned)i;
	if(!u)
		return 0u;

	unsigned sign = u>>31;
	unsigned exp,frac,f;

	if(sign)
		u=(~u)+1;
	unsigned j,leftmost_one;
	for(j=0;j<32;j++)
	{
	leftmost_one=u&(0x80000000>>j);
		if(leftmost_one)
			break;
	}
	exp = 158u-j;
	f = u<<j<<1;

	unsigned last_bit=(f&0x200)>>9;
	unsigned truncation = f&0x1ff;
	if(truncation<0x100)
		frac = f >> 9;
	else if(truncation >0x100)
		frac= (f>>9)+1;
	else 
	{
		if(last_bit)
			frac = (f>>9)+1;
		else
			frac=f>>9;
	}
	if(frac >>23)
	{
		++exp;
		frac=0;
	}
	return (sign<<31)|(exp<<23)|frac;

}

int main()
{
	int i;
	unsigned r;
	float f,fr;
	for(i=INT_MIN;i<=INT_MAX;i++)
	{
		r=float_i2f(i);
		fr=*((float*)&r);
		f=(float)i;
		if(fr == f)
			printf("%d:ok\n",i);
		else
		{
			printf("%d: %f %f error\n",i,f,fr);
			return -1;
		}
		
	}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值