十进制转为二进制

十进制转化为二进制

转化规则
  1. 一般十进制数有整数部分和小数部分组成,两个部分其转化规则是不相同的。因此首先把十进制数的两个部分分开来。
  2. 整数部分:通过除二取余法将余数倒序记录下来,直到除到0
  3. 小数部分:通过乘二取整法将整数正序记录下来。
//十进制转化为二进制
void Switch(float a)
{
	int b = int (a * 100) % 100;
	int v = (a * 100 - b) / 100;  //v为整数部分
	float w = b * 1.0 / 100; //w为小数部分

	//整数部分化为二进制
	int p;
	SqStack S; initStack(S);
	while (v > 0) 
	{
		p = v % 2;
		v /= 2;
		Push(S,p);
	}

	//小数部分化为二进制(保留4位)
	int q[4],n = 0;
	for (int i = 0; i < 4; i++)
	{
		w *= 2;
		if (w > 1)
		{
			q[i] = 1;
			w -= 1;
		}
		else if (w == 1)
		{	
			q[i] = 1;
			break;
		}
		else
			q[i] = 0;
		n++;
	}
	//输出结果
	while (!isEmpty(S))
	{
		Pop(S,p);
		cout << p;
	}
	cout << ".";
	for (int i = 0; i <= n; i++)
		cout << q[i];
	
}
//二进制化十进制
void Switch1(char *str)
{
	char *p = str;
	while (*p != '\0')
	{
		if (*p == '1' || *p == '0' || *p == '.')
			p++;
		else
		{
			cout << "请输入正确的二进制数" << endl;
			return;
		}
		
	}
	char *begin = str, *end = str; //p记录小数点的位置
	while (*end != '\0' && *end != '.')
		end++;
	p = end;
	end--; //end指向整数部分最后一位
	int i = 0;float a = 0; //指数
	while (begin != end)
	{
		if (*end == '1')
			a += pow(2 * 1.0,i);
		i++;
		end--;
	}
	a += pow(2 * 1.0,i);
	begin = end = p + 1;
	while (*end != '\0')
		end++;
	end--; //end指向小数部分最后一位
	float b = 0; i = -1;
	while (begin != end)
	{
		if (*begin == '1')
			b += pow(2 * 1.0,i);
		i--;
		begin++;
	}
	b += pow(2 * 1.0,i);
	cout << a + b;
}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值