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


相关推荐

  • 网站开发团队成员(项目团队)

    1.项目带头人(Boss):通常是项目的发起人,为项目规划企业战略目标,对项目的成败负最终责任。2.项目经理:这个不用说了是项目当然需要PM,建议是通过PMP认证的项目经理,主要负责项目各个过程的管理,以及过程优化降低开发风险。 3.系统架构师:架构师不单单是技术架构,还

    2022年4月10日
    139
  • 手机怎么识别图片上的文字「建议收藏」

    手机怎么识别图片上的文字「建议收藏」 识别提取文字的方法有很多,大家平时也都会使用到自己的方法,但是你所使用到的方法是不是简单而且识别效果很不错呢?其实手机里有很多的识别转换工具,但是很多的识别效果都不如人意,小编最近发现的一个简单有效的方法,一起来看看吧。1.首先在应用市场里找到如下的拍照识别文字工具,然后将其运行。2.在主页点击右下角的蓝色加号按钮然后会出现两个蓝色的小图标,分别是相册和相机,在此选择相机。…

    2022年6月12日
    40
  • C++基本概念_c语言 c++区别

    C++基本概念_c语言 c++区别1.    面向对象的程序设计思想是什么?答:把数据结构和对数据结构进行操作的方法封装形成一个个的对象。 2.    什么是类?答:把一些具有共性的对象归类后形成一个集合,也就是所谓的类。 3.    对象都具有的二方面特征是什么?分别是什么含义?答:对象都具有的特征是:静态特征和动态特征。静态特征是指能描述对象的一些属性;动态特征是指对象表现出来的行为;

    2022年10月3日
    1
  • 自动化安装系统

    自动化安装系统

    2021年8月22日
    71
  • c语言字符串去重_putchar输出字符串

    c语言字符串去重_putchar输出字符串输入一串字符,然后去重。如:输入aaabbbbd;输出应为abd;#include<iostream>#include<string>usingnamespacestd;intmain(){intn;cin>>n;//n表示你要处理多少组stringa;//定义字符串for(inti=0;i<n;…

    2025年6月16日
    3
  • stringutils.isnotblank()_String java

    stringutils.isnotblank()_String java今天在做SSM系统时候,为了进行查询特意使用StringUtils.isNotBlank(name)一定注意导入的包是:importorg.apache.commons.lang3.StringUtils;开始使用的是com.mysql.jdbc中的StringUtils.isNullOrEmpty,,,结果导致在我进行查询的时候各种错误,特地来此总结一番。StringUtils方法的

    2022年8月12日
    8

发表回复

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

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