十进制数负三的二进制数补码为_-8的补码

十进制数负三的二进制数补码为_-8的补码十进制转二进制补码(正负都可)指针初学将一个十进制正(负)整数转换为对应的二进制补码(用指针完成十进制转二进制:1.先判断该整数是正数还是负数如果是正数则二进制补码首位为1,且对应的二进制补码就是原.如果是负数则二进制补码为原码基础上取反且末位加1(加1则涉及进位)代码:#include”stdio.h”#include”Stdio.h…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

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

将一个十进制正(负)整数转换为对应的二进制补码(用指针完成

十进制转二进制: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.二进制补码 百度百科.

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/180121.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Arm-A53资料「建议收藏」

    2012年10月Cortex-A53推出了市场,它带来了ARMv8指令集,在高能效比、节省面积基础上还有显著的性能提升。目前Cortex-A53已可以授权,ARM多个合作伙伴会在2014年推出相关芯片。开发者、OEM厂商和SoC设计者需要了解的Cortex-A53的几个重要特点如下:1、ARM低功耗/高效率的传承ARM9是ARM历史上授权最多的处理器,有超过250个授权。它树立了一个非常重要的功率/成本平衡的最有效点。基于ARM926的功能手机(Nokia…

    2022年4月13日
    274
  • Pytorch深度学习实战教程:UNet模型训练

    Pytorch深度学习实战教程:UNet模型训练1前言本文属于Pytorch深度学习语义分割系列教程。该系列文章的内容有:Pytorch的基本使用语义分割算法讲解由于微信不允许外部链接,你需要点击页尾左下角的“阅读原文”,才能访…

    2022年6月19日
    30
  • pycharm 条件断点_linux打断点

    pycharm 条件断点_linux打断点前言遇到一个问题,由于数据量较大,直接debug调试太费时间,看了上面链接的博文,结合自身实践,于是有了这篇博文。流程打断点,右键断点,condition填入条件(当条件为true时会进入断点,开始调试),debug运行。具体如图。注:循环内赋值的变量可能无法使用,可用赋值前的变量代替,如b=A.a;条件里写A.a<100等等。其他debug用法只记录,不进行debug…

    2022年10月26日
    0
  • java运算符及优先级由高到低_java中运算符优先级排序

    java运算符及优先级由高到低_java中运算符优先级排序一篇关于java运算符以及优先级的文章

    2025年6月5日
    0
  • R语言开发工具之eclipse+StatET

    R语言开发工具之eclipse+StatET

    2022年3月3日
    41
  • 计算滚动条的宽度–js

    计算滚动条的宽度–js原理创建两个div嵌套在一起外层的div设置固定宽度和overflow:scroll滚动条的宽度=外层div的offsetWidth-内层div的offsetWidth实现代码/***获

    2022年7月1日
    21

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号