数据的表示和存储 第2讲 定点数的编码表示

news2024/9/20 14:31:18

深耕AI

互联网行业 算法研发工程师

全文概括:

本讲介绍了定点数的编码表示,主要包括原码、补码和移码

原码表示方式简单,正数用0表示,负数用1表示,但存在表示不唯一和加减运算不统一的问题。

补码表示方式解决了这些问题,正数的补码与原码相同,负数的补码:是其原码取反再加1

模运算系统种,可以用加法代替减法。比如:10-4,就等于,10+8(-4的补码)。

-1928的补码,等于模减去这个数的绝对值,也就是10的4次方,减去1928。

因为:一个负数的补码,等于模减去这个数的绝对值。

4位10进制的模,就是0000---9999,一共10的4次方个数,也就是10的4次。

17900除以10000,得到的余数,就是7900。在这个模运算中,7900,就是与17900等价的一个数。

计算机内部的 表示,就是用2进制来实现的,就像是一个2进制的算盘(只能拨0和1)。

2的8次方 二进制表示(1后面8个0):1 0000 0000。

1 0000 0000 - 0100 0000 = 1100 0000.

因此,一个负数【- 0100 0000】的补码,等于对应正数补码的各位取反,末尾加1。【1100 0000】。

一道题

假定补码位数为8,-1000这个二进制数的补码表示为( )。

  1. 十进制的 8 转换为二进制是 1000(4 位)。
  2. 填充为 8 位
  • 为了将其表示为 8 位,前面需要补充 0:
  • 所以,8 的 8 位二进制表示为 00001000。

所以,正数的补码还是它本身,因为除以模取余数,还是它。

负数的补码,就是模减去这个数的绝对值。

举例:-8,它的补码是多少?

-8是真值,就是2的4次方(1 0000),减去8(1000)。结果是:01000。

下列文章小结:

补码的定义和计算方法。

对于正数的补码表示,直接将数值部分照抄即可;

对于负数的补码表示,将数值部分各位取反末尾加一。

补码的计算可以用公式带入求解,也可以用简便方法从右往左找到第一个1前面的各位取反。

补码的表示可以用于存放中间结果,即使发生溢出也可以用变形补码表示。

正零和负零的补码表示是一样的。

最后,通过例子演示了如何根据补码求出真正的值。

10...01...0=1...0 (n-1个零)

-0的补码,还是00....00【n个0】,因为(2的次方【10...0,n个0】-0还是模本身,然后再除以模,等于又去掉了最高位,所以,还是000....00【n个0】)

负数是以原码的补码形式表达的!!!!!

比如,对于32位表示的-1,它的机器数是多少?

1 0000 0000 0000 0000 0000 0000 0000 0000

- 0000 0000 0000 0000 0000 0000 0000 0001

= 1111 1111 1111 1111 1111 1111 1111 1111【答案】


解析:

进一步的,转换为16进制,就是85H。

1.通过二进制转十进制,十进制再转16进制的方法,间接实现二进制转16进制的过程

1111 = 8 + 4 + 2 + 1 = 15 =F
1110 = 8 + 4 + 2 + 0 = 14= E
1101 = 8 + 4 + 0 + 1 = 13= D
1100 = 8 + 4 + 0 + 0 = 12 =C
1011 = 8 + 0 + 2 + 1 = 11= B
1010 = 8 + 0 + 2 + 0 = 10 =A
1001 = 8 + 0 + 0 + 1 =9 =9
……
0001 = 0 + 0 + 0 + 1 = 1= 1
0000 = 0 + 0 + 0 + 0 = 0= 0

2.二进制转十六进制

有1得出

1111 1101 , 1010 0101 , 1001 1011
     F D ,        A 5 ,        9 B

根据补码各位上的“权”,可以求出一个补码的值。

因为补码的最高位是1表示负数,所以,要✖(-1)。-0和0一样,所以就在公式的最前面直接加了一个负号。

1101 0110,这个第一位是1,表示是负数,它的真值怎么算呢?

因为它是由原码的各位取反,末尾加1得到的,因此,可以先减去1,然后各位取反,就得到了:

0010 1010,换算为10进制,就是32+8+2=42。再把负号加上,就是-42。

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

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

相关文章

zabbix“专家坐诊”第256期问答

原作者:乐维社区 原文链接:https://forum.lwops.cn/questions 问题一 Q:zabbix 6.4.18版本的,使用zabbix_agentd2监控mysql数据库,只能在界面配置mysql的相关信息吗?这个在zabbix表里面是明文存储的&#x…

集采良药:从“天价神药”到低价良药,伊马替尼的真实世界研究!

在医疗科技日新月异的今天,有一种药物以其卓越的疗效和深远的影响力,成为了众多患者心中的“精准武器”——伊马替尼。这款药物不仅在慢性髓细胞白血病(CML)的治疗上屡创佳绩,更是胃肠道间质瘤(GIST&#x…

微信小程序自定义navigationBar顶部导航栏(背景图片)适配所有机型,使用tdesign-miniprogram t-navbar设置背景图片

设置导航栏样式自定义 一定要设置,不然页面会出现一个原生的导航栏,一个自定义的 // app.json文件 "window": {"navigationStyle": "custom" }设置导航栏样式 我这里使用tdesign-miniprogram t-navbar,t-na…

大模型的热度正在下降,大模型的未来在哪里?

“ 技术是一个需要沉淀和厚积薄发的过程 ” 任何事物都会经过起步,发展,顶峰,平稳,下降,灭亡的过程,大模型技术也不例外。 而从现今的趋势来看,大模型的热度正在不断下降,这到底意…

虫情测报灯的工作原理

型号:TH-CQ1】虫情测报灯是一种专门用于监测农田、林区等环境中昆虫数量和种类的设备,也称为智能虫情测报灯或物联网虫情测报灯。它通过特定的光源和颜色吸引昆虫,并利用高压电网或远红外自动处理技术等手段将昆虫击杀或处理,从而…

《黑龙江水产》是什么级别的期刊?是正规期刊吗?能评职称吗?

问题解答 问:《黑龙江水产》是不是核心期刊? 答:不是,是知网收录的第一批认定 学术期刊。 问:《黑龙江水产》级别? 答:省级。主管单位:黑龙江省农业农村厅 …

【QT】系统-下

欢迎来到Cefler的博客😁 🕌博客主页:折纸花满衣 🏠个人专栏:QT 目录 👉🏻QTheadrun() 👉🏻QMutex👉🏻QWaitCondition👉🏻Q…

视频存储EasyCVR视频监控汇聚管理平台设备录像下载报错404是什么原因?

EasyCVR视频监控汇聚管理平台是一款针对大中型项目设计的跨区域网络化视频监控集中管理平台。该平台不仅具备视频资源管理、设备管理、用户管理、运维管理和安全管理等功能,还支持多种主流标准协议,如GB28181、RTSP/Onvif、RTMP、部标JT808、GA/T 1400协…

基于SpringBoot的智能排课系统设计与实现

文未可获取一份本项目的java源码和数据库参考。 (一)选题来源与背景 高校的每学期伊始,排课是教务处工作中的重中之重。安排合理无资源冲突(教师、教室和设备等教学资源)的课表是教务工作必须面临的问题。传统的人工…

规模化电动汽车接入配电网调度方法

规模日益增长的电动汽车和可再生能源带来的不确定性给配电网的安全运营带来了严峻挑战。为综合考虑多重不确定性、平衡运营成本与系统可靠性,首先,提出一种基于分布鲁棒联合机会约束的电动汽车-配电网充放电调度模型。该模型将节点电压、支路功率、备用需求等通过联合机会约束建…

由一个 SwiftData “诡异”运行时崩溃而引发的钩深索隐(六)

概述 在 WWDC 24 中,苹果推出了数据库框架 SwiftData 2.0 版本。听说里面新增了能让数据记录“借尸还魂”的绝妙法器,到底是真是假呢? 我们在上篇博文中介绍了 History Trace 是如何稳妥的处理数据删除操作的。而在这里,我们将继续介绍 SwiftData 2.0 中另一个新特性:“墓…

Prometheus - nVisual插件让运维更轻松

Prometheus 是一个开源的服务监控系统和时间序列数据库,常用于对基础设施的监控,监控范围涵盖了硬件层、操作系统层、中间件层、应用层等运维所需的所有监控指标类型,同时可利用第三方可视化工具Grafana实现时序数据的展示。然而,…

Redis基础(数据结构和内部编码)

目录 前言 Redis的数据结构和内部编码 string结构和内部编码 string数据机构的特点 string数据结构的内部编码 list结构和内部编码 List 数据结构的特点 List 的内部编码 1. ziplist(压缩列表) 2. quicklist hash结构和内部编码 hash数据结构…

OpenCV特征检测(3)计算图像中每个像素处的特征值和特征向量函数cornerEigenValsAndVecs()的使用

操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C11 算法描述 计算图像块的特征值和特征向量用于角点检测。 对于每一个像素 p ,函数 cornerEigenValsAndVecs 考虑一个 blockSize blockSize 的邻…

Java 在 GIS 领域的学习路线?

Java是一门广泛应用于企业级开发的编程语言,而GIS则是一种常用于地理信息处理和分析的技术。将Java与GIS结合起来,可以在企业级应用中实现更多的功能和业务需求,且在实际领域越来越广泛。 Java在GIS中重要的作用 1、跨平台性 Java具有跨平台…

基于C语言+SQL Server2008实现(控制台)图书管理系统

第1章 概述 1.1项目背景 随着科技的发展,尤其是计算机技术的迅猛发展,图书馆管理的问题从以往的人工管理,到现在的电脑化,系统化,是对图书馆管理方法的质的飞跃,这些技术不仅让图书馆管理变得更加方便、快…

美国联邦基金有效利率及目标利率历史数据集(1990.1-2024.9)

美联储在2024年9月18日宣布将其调50个基点,降至4.75%至5.00%之间的水平。这是美联储自2020年3月以来首次降息,也是自2023年7月将利率水平调升至历史高位后的首次下调,标志着货币政策由紧缩周期向宽松周期的转向。一、数据介绍 数据名称&…

web基础—dvwa靶场(八)XSS

XSS(DOM) 跨站点脚本(XSS)攻击是一种注入攻击,恶意脚本会被注入到可信的网站中。当攻击者使用 web 应用程序将恶意代码(通常以浏览器端脚本的形式)发送给其他最终用户时,就会发生 XSS 攻击。允许这些攻击成…

网络-内核是如何与用户进程交互

1、socket的直接创建 net/socket.cSYSCALL_DEFINE3(socket, int, family, int, type, int, protocol) {...retval sock_create(family, type, protocol, &sock);... }int sock_create(int family, int type, int protocol, struct socket **res) {return __sock_create(cu…

字符串函数的使用与模拟(2)——C语言内存函数

目录 1. memcpy函数的使用与模拟 2. memmove函数的使用与模拟 3. memset函数的使用 4. memcmp函数的使用 5. memchr函数的使用 前言&#xff1a;C语言内存函数是一组用于直接操作计算机内存的内置函数。使用时要包含头文件<string.h> 1. memcpy函数的使用与模拟 函…