进制的转换

1、进制的转化

(1)进制介绍

        对于进制,有四种表示方法:

        1)二进制:0,1,满2进1,C语言中没有二进制常数的表示方法

        2)八进制:0-7,满8进1

        3)十进制:0-9,满10进1

        4)十六进制:0-9及A-F(A-F分别表示10~15),满16进1.以0X或者0x表示,此处的A-F不区分大小写。

2、进制的转换

(1)进制转换的介绍

        第一组(其他进制转换十进制)

        1)二进制转十进制

                规则:从最低位开始,将每个位上的数提取出来,乘以2的(位数减1)次方,然后求和。

        2)八进制转十进制

                规则:从最低位开始,将每个位上的数提取出来,乘以8的(位数减1)次方,然后求和。 

        3)十六进制转十进制

                 规则:从最低位开始,将每个位上的数提取出来,乘以16的(位数减1)次方,然后求和。 

                0x34A(16进制)=842(十进制),虽然A在16进制中表示10,但是它植被看做一位,所以0x34A=10*16^(1-1)+4*16^(2-1)+3*16^(3-1)=842。

        第二组(十进制转换其他进制)

        1)十进制转二进制

                规则:将该数不断除2,直到商为0为止,然后将每步得到的余数都倒过来,就是对应的二进制数。

        56(十进制)=111000(二进制)

        56/2=28...0        28/2=14...0        14/2=7...0        7/2=3...1        3/2=1...0        1/2=0...1

        所得余数为000111,他代表的十进制数是1*2^(1-1)+1*2^1+1*2^2=7,将这个余数反过来之后,就变成了111000,他代表的十进制数是1*2^3+1*2^4+1*2^5=56。

        这个例子有些特殊,我们看似是把每位取反,实则不然,而是将每一位和其对称的那一位的位置进行了调换。

        2)十进制转八进制

               规则:将该数不断除8,直到商为0为止,然后将每步得到的余数都倒过来,就是对应的八进制数。   

                156(十进制)=234(八进制)

                156/8=19...4        19/8=2...3        2/8=0...2

                所得余数为432,反过来之后就是234,4*8^0+3*8+2*8^2=156。

        3)十进制转十六进制

                 规则:将该数不断除16,直到商为0为止,然后将每步得到的余数都倒过来,就是对应的十六进制数。

                356(十进制)=164(十六进制)

                356/16=22...4        22/16=1...6        1/16=0...1

                所的余数反过来之后就是164,4*16^0+6*16+1*16^2=356。

        第三组(二进制转其他进制)

        1)二进制转八进制

                规则:将二进制每三位一组,缺的位补0,转成对应的十进制数,再把这些十进制数组合起来即可

                11010101(二进制)=325(八进制)

                先把二进制数每三位一组分开,分别是011、010、101,注意,每组所代表的十进制数分别为3、2、5,所以对应的八进制数就是325了

        2)二进制转十六进制

                规则:从低位开始,将二进制数每四位一组,转成对应的十进制数,再看这些十进制数有没有大于9的,如果有,转换为对应的16进制即可

                11010101(二进制)=

                先把二进制数从低到高每四位一组分开分别是1101、0101,他们代表的十进制数是

13、5,13在十六进制中代表的D,所以这个二进制转换成十六进制就是D5。

        第四组(其他进制转二进制)

        1)八进制转二进制

                将八进制每一位,转换成对应的一个三位的二进制数即可

                0237(八进制)=000010011111(二进制)=01001111(二进制)

        2)十六进制转二进制

                将十六进制每一位,转成对应的一个四位的二进制数即可

                0x23B(十六进制)=001000111011(二进制)=1000111011(二进制)

                          

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/139628.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ubuntu上如何移植thttpd

thttpd的特点 thttpd 是一个简单、小巧、便携、快速且安全的 HTTP 服务器。 简单: 它只处理实现 HTTP/1.1 所需的最低限度。好吧,也许比最低限度多一点。 小: 请参阅比较图表。它还具有非常小的运行时大小,因为它不会分叉并且非…

MapReduce编程——矩阵乘法(Python版本)

数据格式 对于矩阵元素 A i j A_{ij} Aij​&#xff0c;将其处理为 < i , j , M a t r i x N a m e , v a l u e > <i,j,MatrixName,value> <i,j,MatrixName,value>的四元组格式&#xff0c;例如矩阵[[2, 1, 3, 4], [10, -8, 7, 2], [9, 1, 6, -2]]可被转化…

牛客网刷题笔记131111 Python实现LRU+二叉树先中后序打印+SQL并列排序

从学校步入职场一年多&#xff0c;已经很久没刷过题了&#xff0c;为后续稍微做些提前的准备&#xff0c;还是重新开始刷刷题。 从未做过计划表&#xff0c;这回倒是做了个计划表&#xff0c;希望能坚持吧。 刷题比较随性且量级不大&#xff0c;今天就写了2个算法2个sql&#x…

LeetCode257. Binary Tree Paths

文章目录 一、题目二、题解 一、题目 Given the root of a binary tree, return all root-to-leaf paths in any order. A leaf is a node with no children. Example 1: Input: root [1,2,3,null,5] Output: [“1->2->5”,“1->3”] Example 2: Input: root […

uniapp本地存储的几种方式

在UniApp中&#xff0c;你可以使用本地存储来保存和获取数据&#xff0c;以便在应用的不同页面之间共享数据或在应用关闭后仍然保存数据。UniApp提供了两种主要的本地存储方式&#xff1a;uni.setStorage 和 uni.getStorage&#xff0c;以及 uni.removeStorage 用于删除数据。这…

无需公网IP,贝锐花生壳内网穿透远程访问NAS

群晖DSM 7.0及以上版本 1.1 安装运行花生壳套件 &#xff08;1&#xff09;通过浏览器输入群晖NAS的内网地址&#xff0c;登录进去后&#xff0c;点击【套件中心】&#xff0c;搜索【花生壳】&#xff0c;并点击【安装套件】&#xff1b; &#xff08;2&#xff09; 勾选我接…

ZooKeeper基本知识

1.什么是ZooKeeper ZooKeeper是一个开源的分布式协调服务&#xff0c;它提供了一个高性能、高可靠的分布式协调基础&#xff0c;用于构建分布式系统。 具体来说&#xff0c;ZooKeeper通常用于以下几个方面&#xff1a; 配置管理&#xff1a;分布式系统通常需要集中管理配置信…

Java设计模式-创建者模式-单例模式

单例模式 单例模式饿汉式懒汉式 单例模式 解释&#xff1a;一个类只能有一个实例 单例模式可以分为两种 饿汉式 和 懒汉式 饿汉式 也被称为预加载&#xff0c;即 在加载类的时候&#xff0c;就将实例创建出来&#xff0c;加载到内存&#xff0c;不管之后会不会使用这个实例 …

Jvm虚拟机

问题&#xff1a; 计算机能识别的语言是二进制&#xff0c;Java文件是程序员编写的&#xff0c;如何能够在计算机上运行&#xff1f; 以及Java为什么可以实现跨平台&#xff1f; 一Java的jdk中有jvm虚拟机 可以将文件转换为字节码文件 使得它可以在各种平台上运行&#xff0c;这…

Openlayers:自定义Controls

Openlayers是一款优秀的二维开源地图框架,支持矢量/栅格图层,支持移动端,并且易于自定义和拓展。下面来讲述一下自定义Control的基本思路。 openlayers-features 问题描述 最近在做个人项目时,遇到了一个小问题,就是在地图中心添加一个十字针形状的符号,用来表示地图中心…

Java入门篇 之 补 类与对象

本篇碎碎念&#xff1a;每个人的想法都不一样&#xff0c;不要强求&#xff0c;顺其自然&#xff0c;要相信&#xff0c;一切都在向好的方面前进&#xff01;&#xff01;&#xff01;&#xff01; 今日份励志文案:山海的浩瀚&#xff0c;宇宙的浪漫&#xff0c;都在我内心翻腾…

LeetCode200.岛屿数量

看完题目我还感觉这道题目有点难&#xff0c;没想到20分钟不到就完全靠自己给写出来了。我就是按照自己的想法来&#xff0c;我用一个等大的visit数组来表示grid数组中的这个元素是否被访问过&#xff08;是否已经被判断了是不是岛屿&#xff09;。 先用一个大的循环对grid数组…

贝锐蒲公英X1解决远程访问NAS难题

由于经常在外出差和旅游&#xff0c;需要实现即使在外地也能远程登录回去家里的NAS去处理事情或传输文件&#xff0c;因此解决方案之一是搭建一个安全简易的个人私有云。 实施难度 &#xff08;1&#xff09;家庭网络无公网IP&#xff0c;且公网IP价格昂贵&#xff08;2&…

Django的ORM操作

文章目录 1.ORM操作1.1 表结构1.1.1 常见字段和参数1.1.2 表关系 2.ORM2.1 基本操作2.2 连接数据库2.3 基础增删改查2.3.1 增加2.3.2 查找2.3.4 删除2.3.4 修改 1.ORM操作 orm&#xff0c;关系对象映射&#xff0c;本质翻译的。 1.1 表结构 实现&#xff1a;创建表、修改表、…

Python用requests库采集充电桩LBS位置经纬度信息

这是一个使用Python的requests库来爬取网页内容的示例。首先&#xff0c;我们需要导入requests库。然后&#xff0c;我们需要定义一个函数来处理请求。在这个函数中&#xff0c;我们需要设置爬虫IP服务器的URL和端口号&#xff0c;然后使用requests.get来获取网页内容。最后&am…

GoF之代理模式

2023.11.12 代理模式是GoF23种设计模式之一&#xff0c;其作用是&#xff1a;为其他对象提供一种代理以控制对这个对象的访问。在某些情况下&#xff0c;一个客户不想或者不能直接引用一个对象&#xff0c;此时可以通过一个称之为“代理”的第三者来实现间接引用。代理对象可以…

JavaScript理解表达式和语句的含义

JavaScript中的表达式和语句都是用于完成特定计算或操作的语言构件&#xff0c;但它们有着不同的含义和用途&#xff1a; 表达式(expression)是用来计算并返回一个值的代码片段&#xff0c;可以包含变量、数值、函数调用、运算符等。表达式的运算结果可以被赋值给变量、作为函数…

FlinK之检查点与保存点机制

检查点与保存点 检查点Checkpoint概述保存时机保存与恢复检查点算法 检查点配置启用检查点指定存储位置其它配置通用增量 保存点Savepoint概述使用保存点切换状态后端 SQL客户端中操作提交作业触发恢复 检查点Checkpoint 概述 在 Flink 中&#xff0c;检查点是用于实现状态一致…

状态图和活动图的含义及其区别

状态图主要用于描述一个对象在其生存期间的动态行为&#xff0c;表现一个对象所经历的状态序 列&#xff0c;引起状态转移的事件(event)&#xff0c;以及因状态转移而伴随的动作(action)。 活动图可以用于描述系统的工作流程和并发行为。活动图其实可看作状态图的特殊形 式&am…

解决springboot接受buffer文件为null(从picgo上传buffer看springmvc处理过程)

1. 前言&#xff1a; picgo插件的简单开发 上篇文章我们简单写了picgo上传插件&#xff0c;但是当我们测试的时候&#xff0c;发现问题了&#xff0c;后端MultipartFile file接受到的文件为null。 2. 排查问题&#xff1a; 参考的文档 picgo api列表关于multipart form-data中…