十进制负数转换为二进制、八进制、十六进制的知识分享

下面是关于“十进制负数转换为二进制、八进制、十六进制”的详细讲解。

一、前置知识

在进行负数的进制转换前,需要了解以下几点:

1.原码

原码是一个二进制数的最高位表示这个数的符号,为 0 代表正数,为 1 代表负数。其余各位位数表示这个数的绝对值的二进制数。如以下几个数的原码:
+1 的原码:00000001
-1 的原码:10000001
+5 的原码:00000101
-5 的原码:10000101

2.反码

反码和原码一样,最高位表示符号,其余各位表示数值。对于正数而言,反码与原码相同,对于负数则是在原码的基础上,各位取反(0变为1,1变为0)。如以下几个数的反码:
+1 的反码和原码相同:00000001
-1 的反码:11111110
+5 的反码和原码相同:00000101
-5 的反码:11111010

3.补码

补码是对反码进行修正,使得减法能够转化为加法,减法的得出的结果直接是补码。对于正数而言,补码与原码相同,对于负数则是在反码的基础上,末位加 1。如以下几个数的补码:
+1 的补码和原码相同:00000001
-1 的补码:11111111
+5 的补码和原码相同:00000101
-5 的补码:11111011

二、二进制转换

在了解了原码、反码、补码的概念后,我们可以开始进行负数的二进制转换。

1.将负数的补码取反

将十进制负数转换为二进制,需要先得到其补码。对于负数补码,按位取反,将二进制 0 和 1 互换即可。例如 -5 的补码为:1111 1011,其反码为 1000 0100。

2.将补码加 1

将补码进行加 1 操作,结果就是负数的二进制表示。例如 -5 的反码为 1000 0100,加 1 后即为 1000 0101。

举个例子,如果我们想将十进制的 -9 转化为二进制数表示。其绝对值 9 的二进制为 1001。加上符号位后,得到原码 1001。其反码为 1111(1001取反),补码为 0001,然后按照上述的步骤,将补码取反并加 1,得到 -9 的二进制表示为 111110111。

三、八进制转换

以下是将十进制负数转换为八进制数的步骤。

1.将负数转换为二进制

使用前面讲解的步骤,将十进制负数转化为二进制。

2.若二进制数的位数不是 3 的倍数,前面补足 0

例如,将负数 -15 转换为二进制为 1111。由于 1111 的位数不是 3 的倍数,需要在前面补足 0,变成 011 111。

3.将二进制转换成八进制

按照每三位分组的规则进行转换,即 011 111 的八进制表示为 57。

举个例子,如果我们想将负的十进制数 -37 转化为八进制表示。其绝对值为 37,转换为二进制数的结果是 100101,对齐到三位,前面加 0,即 100 101,转化为八进制表示后即为 045,加上负号,表示为 -45。

四、十六进制转换

以下是将十进制负数转换为十六进制数的步骤。

1.将负数转换为二进制

使用前面讲解的步骤,将十进制负数转化为二进制。

2.若二进制数的位数不是 4 的倍数,前面补足 0

例如,将负数 -15 转换为二进制为 1111。由于 1111 的位数不是 4 的倍数,需要在前面补足 0,变成 1111 0000。

3.将二进制转换成十六进制

按照每四位分组的规则进行转换,即 1111 0000 的十六进制表示为 F0。

举个例子,如果我们想将负的十进制数 -100 转化为十六进制表示。其绝对值为 100,转换为二进制数的结果是 1100100,对齐到四位,前面加 0 即可,即 0110 0100,转化为十六进制表示后即为 64,加上负号,表示为 -64。

【示例说明】如果我们要把 -34 转换成八进制,我们可以把 -34 的绝对值转换成二进制 100010,前面补足成 001 000 010,然后按照每三位分组的规则进行转换,即 001 000 010 的八进制表示为 042,所以 -34 转换成八进制表示为 -042。

【示例说明】如果我们要将 -154 转换成十六进制,我们先将其转换成补码,即先将绝对值转换为二进制数 1001 1010,再将其转换为反码 1110 0101,最后将其转换为补码 1110 0110。再按照十六进制转换规则,对齐成 1110 0110 的十六进制表示为 E6,所以 -154 转换成十六进制表示为 -E6。

以上内容就是将十进制负数转换为二进制、八进制、十六进制的知识分享,希望对你有所帮助。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:十进制负数转换为二进制、八进制、十六进制的知识分享 - Python技术站

(0)
上一篇 2023年6月8日
下一篇 2023年6月8日

相关文章

  • C#打印绘图的实现方法

    C#可以使用绘图技术实现各种详细复杂的图形和文本,可以在窗体、控件等多个对象上进行绘制。这里提供一份“C#打印绘图的实现方法”的攻略供您参考。 1. 打印机 在使用 C# 绘制和打印图表之前,需要获得系统安装的可用打印机列表,以便用户选择要打印作业的打印机。通过 System.Drawing.Printing.PrinterSettings.Installe…

    C# 2023年6月1日
    00
  • C#中Lambda表达式的三种写法

    下面我将为你讲解C#中Lambda表达式的三种写法的完整攻略。 1. 简单Lambda表达式 在C#中,我们可以使用Lambda表达式来简化匿名方法的编写。Lambda表达式有三个部分组成:参数列表、箭头(Lambda符号)和Lambda方法体,在下面的例子中,我们使用Lambda表达式实现了一个简单的加法方法: int Add(int a, int b) …

    C# 2023年6月1日
    00
  • 盘点C# 9.0中好用的特性

    顶级语句 将类和类里面Main函数省略,只留下核心的逻辑代码就是顶级语句! 1.顶级语句1 await System.Threading.Tasks.Task.Delay(1000); System.Console.WriteLine(“Hi!”); return 0; static class $Program { static async Task&lt…

    C# 2023年4月24日
    00
  • C#开发微信门户及应用(5) 用户分组信息管理

    C#开发微信门户及应用(5) 用户分组信息管理 在微信公众平台开发中,我们可以通过对微信用户分组进行管理,实现对不同用户的针对性管理。本篇文章将介绍C#开发微信门户及应用中的用户分组信息管理。 1. 获取分组列表 我们可以通过向微信服务器发送请求来获取已有分组列表。代码示例: var accessToken = "your_access_token…

    C# 2023年5月31日
    00
  • C#线程池ThreadPool用法简介

    C#线程池ThreadPool用法简介 简介 C# 线程池(ThreadPool)是 .NET Framework 的一个重要组件,它可以管理和调度运行于多个工作线程上的任务,这样就可以避免频繁地创建和销毁线程。 采用线程池的方式可以优化应用程序的性能,同时降低系统的负担。 使用 使用线程池需要使用 System.Threading 命名空间中的 Threa…

    C# 2023年6月6日
    00
  • VS2015 C#生成dll文件的方法(32/64)

    生成dll文件是C#程序开发中的常见需求之一,下面是在VS2015中生成32/64位dll文件的完整攻略。 生成32位dll文件的攻略 打开Visual Studio 2015软件,点击File -> New -> Project,创建一个新的Class Library项目。 在“Solution Explorer”窗口中右键单击项目名称,选择“…

    C# 2023年5月14日
    00
  • C#飞行棋小程序设计代码

    下面是关于C#飞行棋小程序设计代码的完整攻略。 一、项目介绍 本项目是一个基于C#语言开发的飞行棋小程序,主要实现了玩家与AI的对战,包括玩家与玩家的双人模式和玩家与AI的单人模式。玩家可以选择自己的棋子并掷骰子前进,并通过各种游戏道具获取优势,最后到达终点即可获胜。 二、技术实现 本项目基于Windows Forms应用程序开发,主要涉及到以下技术实现: …

    C# 2023年5月31日
    00
  • C# File.AppendText(string path):在指定文件末尾添加文本内容,并返回StreamWriter对象

    File.AppendText(string path) 是C#中的一个方法,用于向指定文件的末尾追加文本内容,如果文件不存在则会创建。下面是该方法的完整攻略: 方法定义: public static StreamWriter AppendText(string path) 方法参数: path:字符串,表示要追加文本的文件名和路径。 方法返回值: Stre…

    C# 2023年4月19日
    00
合作推广
合作推广
分享本页
返回顶部