十进制数负三的二进制数补码为_-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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • sql server 日期转字符串_db2 日期转字符串

    sql server 日期转字符串_db2 日期转字符串Whileworkingwithrawdata,youmayfrequentlyfacedatevaluesstoredastext.Convertingthesevaluestoadatedatatypeisveryimportantsincedatesmaybemorevaluableduringanalysis.In…

    2022年10月8日
    2
  • navicat15 永久激活码最新_最新在线免费激活

    (navicat15 永久激活码最新)好多小伙伴总是说激活码老是失效,太麻烦,关注/收藏全栈君太难教程,2021永久激活的方法等着你。IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html1STL5S9V8F-eyJsaWNlbnNlSW…

    2022年3月27日
    62
  • Could not retrieve transation read-only status server「建议收藏」

    背景最近在部署一套完整的项目,部署过程中遇到很多的问题,在来总结一些如标题的这个错误!环境说明: 使用分布式数据库,使用的是mysql!### Cause: java.sql.SQLException: Could not retrieve transation read-only status server; SQL []; Could not retrieve tran…

    2022年2月27日
    54
  • CListCtrl

    CListCtrl建立变量m_listCtrl:选中控件ctrl+鼠标左键双击添加控件风格:DWORDexstyle=m_ListCtrl.GetExtendedStyle();m_ListCtrl.SetExtendedStyle(exstyle|LVS_EX_FULLROWSELECT|LVS_EX_GRIDLINES|WS_EX_STATICEDGE);m_ListCt

    2022年6月23日
    27
  • log4cxx 简介

    log4cxx 简介Log4cxx是开放源代码项目ApacheLoggingService的子项目之一,用于为C++程序提供日志功能,以便开发者对目标程序进行调试和审计。本文对log4cxx的使用及配置进行介绍,并给出一个可以快速开始的实例。最后,针对日志服务给出一些实践方面的建议。1.       介绍Log4cxx是开放源代码项目ApacheLoggingService的子项目之一,是Jav

    2022年6月24日
    53
  • toast弹窗什么意思_app加弹窗软件

    toast弹窗什么意思_app加弹窗软件//界面toast提示/*使用方法Toast(‘这是一个弹框’,2000)*/functionToast(msg,duration){ duration=isNaN(duration)?3000:duration; varm=document.createElement(‘div’); m.innerHTML=msg; m.style.cssText=…

    2022年9月24日
    1

发表回复

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

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