C语言 十进制转二进制补码(正负都可) 指针 初学

十进制转二进制补码(正负都可) 指针初学

将一个十进制正(负)整数转换为对应的二进制补码(用指针完成
十进制转二进制:1.先判断该整数是正数还是负数 如果是正数则二进制补码首位为1 , 且对应的二进制补码就是原. 如果是 负数 则二进制补码为原码基础上取反且末位加1(加1则涉及进位 )

代码:

#include"stdio.h"
#include"Stdio.h"
int main()
{
	int *p;
	int x,i;

	printf("输入一个十进制整数:");
	scanf_s("%d", &x);

	p = (int *)malloc(sizeof(int) * 32);//为二进制分配内存空间

	if (x < 0)//负数转正  如果为负数 二进制第一位为1 正数则为0
	{
		*p = 1;
		x = -x;
	}
	else if (x > 0)    *p = 0;
	//判断正负    改首位
	//-----------------------------------------------------------------------
	for(i=31;i>=1;i--)//原码
	{
		*(p+i) = x % 2;
		x = x / 2;
	}
	//-----------------------------------------------------------------------

	//二进制取补码规则;若x为负数则 源码换反码 且反码末位加1
	if (*p == 1)//换反码
	{
		for (i = 1; i <=31; i++)
		{
			if (*(p+i) == 1)       *(p + i) = 0;
			else				   *(p + i) = 1;
		}
	}

	if (*p == 1)//负数
	{
		if (*(p+31) == 0)	*(p + 31) = 1;//最后一位为0 则直接加1
		else if (*(p + 31) == 1)      //最后一位为1   进位 
		{
			for (i = 1; i <= 31; i++)
			{
				if (*(p + 31) + 1 == 2 )//逢2进1
				{
					*(p + 31) = 0;
					*(p +30) += 1;
				}
				else if (i > 0 && *(p + i) == 2)
				{
					*(p + i) = 0;
					*(p + i+1) += 1;
				}
			}
		}
	}

	//-----------------------------------------------------------------------
	for (i = 0; i <= 31; i++)//输出
	{
		printf("%d", *(p + i));
	}
	printf("\n");

	system("pause");
	return 0;
}

运行测试:

测试: 5 结果:000000000000000000000000000101

测试   -5

测试: -5 结果:11111111111111111111111111111011

测试   -5

测试: -7 结果:11111111111111111111111111111011

测试  -7

初学阶段,算法可能有问题,不妥的多提意见…

参考资料:

1.十进制转换为二进制、原码、反码、补码、移码.
2.二进制补码 百度百科.

  • 11
    点赞
  • 63
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值