深入理解计算机系统 家庭作业 2.75

/*

书中的公式是w位的公式(mod 2^{w}就是为了截断成w位),我们现在做的是2w位中的前w位

注意书上这句话:由于模运算符,所有带有权重2^{w}2^{2w}的项都丢掉

对应到本题

该项除以2^{w}后还是超过了2w位所以被丢弃了,因为题目说了只有2w位

这个式子除以2^{w}就是我们想要的最终结果

函数signed_high_prod 的结果((int64_t) x * y )>> 32

对应的是x*y/2^{w}   

函数unsigned_high_prod的结果中x * sig_y + y * sig_x

对应的是 

*/

#include <stdio.h>
#include <stdint.h>#define TMax 2147483647
#define TMin (-TMax - 1)int signed_high_prod(int x, int y);
unsigned unsigned_high_prod(unsigned x, unsigned y);int main(void)
{unsigned x = 4294967295;unsigned y = 4294967295;printf("x*y\t\t%x\n",unsigned_high_prod(x,y));}int signed_high_prod(int x, int y) 
{printf("x*ysigned\t%8llx\n",(int64_t) x * y );printf("x*ysigned>>\t%8llx\n",((int64_t) x * y )>> 32);return ((int64_t) x * y )>> 32;
}unsigned unsigned_high_prod(unsigned x, unsigned y) {unsigned signed_prod = signed_high_prod(x, y);int sig_x = x >> 31;//右移时x还是无符号所以能得到掩码int sig_y = y >> 31;return signed_prod + x * sig_y + y * sig_x;
}

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

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

相关文章

前端学习<四>JavaScript基础——03-常量和变量

常量&#xff08;字面量&#xff09;&#xff1a;数字和字符串 常量也称之为“字面量”&#xff0c;是固定值&#xff0c;不可改变。看见什么&#xff0c;它就是什么。 常量有下面这几种&#xff1a; 数字常量&#xff08;数值常量&#xff09; 字符串常量 布尔常量 自定义…

【独立开发前线】Vol.35 绝大部分人独立开发失败的原因

我自己是一名独立开发者&#xff0c;我也见过几百个独立开发者&#xff0c;有成功的&#xff0c;也有失败的。 成功者的特质各不相同&#xff0c;但失败的都有相同的几点&#xff1b; 程序员做独立开发是很有优势的&#xff0c;通过编程的能力&#xff0c;可以快速实现产品。…

Vol.34 Good Men Project:一个博客网站,每月90万访问量,通过付费订阅和广告变现

今天给大家分享的案例网站是&#xff1a;Good Men Project&#xff0c;这是一个专门针对男性成长的博客网站&#xff0c;内容包括人际关系、家庭、职业发展等话题。 它的网址是&#xff1a;The Good Men Project - The Conversation No One Else Is Having 流量情况 我们先看…

高分卫星助力台湾省花莲县地震应急救援

4月3日7时58分&#xff0c;在台湾省花莲县海域&#xff08;北纬23.81度&#xff0c;东经121.74度&#xff09;发生7.3级地震&#xff0c;震源深度12公里。接中国地震局地震预测研究所应急需求&#xff0c;国家航天局对地观测与数据中心&#xff08;以下简称“中心”&#xff09…

各省-科技创新、研发强度数据集(2007-2022年)

01、数据简介 研发强度是科学技术发展的重要指标&#xff0c;可以反映出一个国家或地区的科技实力和创新能力。研发强度越高&#xff0c;就意味着该地区的科技创新能力越强。 本数据是对全国各省份研发强度统计&#xff0c;数据年份2007至2022年&#xff0c;采用科技支出占GD…

C#仿OutLook的特色窗体设计

目录 1. 资源图片准备 2. 设计流程&#xff1a; &#xff08;1&#xff09;用MenuStrip控件设计菜单栏 &#xff08;2&#xff09;用ToolStrip控件设计工具栏 &#xff08;3&#xff09;用StatusStrip控件设计状态栏 &#xff08;4&#xff09;ImageList组件装载树节点图…

SQLyog连接数据库8.0版本解析错误问题解决方案

问题描述&#xff1a; 解决方案&#xff1a; alter userrootlocalhostidentified with mysql_native_password by 密码; 再次连接就可以了。

实现顺序表的增删查改

现在让我们探索数据结构这个美妙的世界吧&#xff01; 概念介绍 线性表是具有相同特性的数据元素的有限序列。线性表是一种在实际运用中广泛运用的线性结构&#xff0c;如线性表&#xff0c;栈&#xff0c;队列&#xff0c;字符串等。 顺序表的本质是数组&#xff0c;实现了…

UDP和TCP之间的对比

TCP优势可靠传输&#xff08;适合于绝大部分场景&#xff09; UDP优势更高效率&#xff08;适合对于性能敏感的场景如局域网内部之间的通信&#xff09; 如局域网内部之间&#xff08;如机房&#xff09;的主机进行通信&#xff0c;局域网内部之间通信的结构比较简单带宽充足…

js的事件冒泡、捕获、委托

事件不仅存在js中&#xff0c;也存在在其他语言中&#xff0c;js事件背后的主要思想是能够在特定事件发生时运行代码。 先普及一个概念&#xff0c;什么是事件处理程序&#xff1f; 事件处理程序就像一个特殊的通用遥控器&#xff0c;可以执行某些操作&#xff0c;例如更改电…

java自动化-03-04java基础之数据类型举例

1、需要特殊注意的数据类型举例 1&#xff09;定义float类型&#xff0c;赋值时需要再小数后面带f float num11.2f; System.out.println(num1);2&#xff09;定义double类型&#xff0c;赋值时直接输入小数就可以 3&#xff09;另外需要注意&#xff0c;float类型的精度问题…

python学习21:python中的数据容器

python中的数据容器 1.什么是数据容器呢&#xff1f; 一种可以存储多个元素的python数据类型&#xff1b;也就是一种可以容纳多份数据的数据类型&#xff0c;容纳的每一份数据称之为1个元素&#xff1b;每一个元素&#xff0c;可以是任意类型的数据&#xff0c;如字符串&#…

鸿蒙开发就业前景到底怎么样?

随着科技的不断进步&#xff0c;鸿蒙操作系统的推出为开发者们带来了新的机遇和挑战。鸿蒙&#xff0c;作为华为自主研发的操作系统&#xff0c;旨在为消费者提供更为流畅、安全的智能设备体验。那么&#xff0c;鸿蒙开发就业前景如何呢&#xff1f; 一、鸿蒙操作系统的优势 …

探索--------------redis缓存三大问题及解决方案

目录 一、redis的三大缓存问题 1、缓存穿透 1.1 问题描述 1.2缓存穿透发生的条件 1.3缓存穿透发生的原因 1.4解决方案 2、缓存雪崩 2.1问题描述 2.2解决缓存雪崩问题的方法有&#xff1a; 3、缓存击穿 &#xff08;热点数据集中失效&#xff09; 3.1问题描述 3.2缓…

SpringBoot快速入门笔记(3)

文章目录 一、MybatisPlus1、ORM2、添加依赖3、全局配置4、Navicat5、UserController6、CRUD操作7、BaseMapper8、两个注解 二、多表查询1、模拟用户订单2、通过用户查相关订单3、UserMapperNew4、查询订单和所属用户5、OrderMapper6、OrderController 三、条件查询四、分页查询…

【Ubuntu】用 VMware 安装 macOS

本教程使用 Ubuntu 20.04.6 LTS&#xff0c;VMware Workstation Pro 17.5.1&#xff0c;macOS Sonoma 14.4。文中所有需要的下载链接均以 Markdown 的形式体现在文字上。 下载 VMware Workstation Pro&#xff0c;目前最新版本是 17.5.1。 使用密钥&#xff0c;进行破解。 VM…

金融中的数学知识

随机偏微分方程相比普通偏微分方程具有额外的随机项&#xff0c;反映了其描述的现象具有随机性质

SpringCloud微服务治理

微服务治理(Microservice Governance)是管理微服务架构中的各个组件和服务的关键活动,它确保服务间的协作、一致性以及整个系统的稳定性。以下是一些常见的微服务治理策略和工具: 服务注册与发现 Spring Cloud Netflix Eureka:用于服务注册与发现,让服务之间能够找到彼…

【核弹级安全事件】XZ Utils库中发现秘密后门,影响主要Linux发行版,软件供应链安全大事件

Red Hat 发布了一份“紧急安全警报”&#xff0c;警告称两款流行的数据压缩库XZ Utils&#xff08;先前称为LZMA Utils&#xff09;的两个版本已被植入恶意代码后门&#xff0c;这些代码旨在允许未授权的远程访问。 此次软件供应链攻击被追踪为CVE-2024-3094&#xff0c;其CVS…

中国大学生计算机设计大赛—软件应用与开发赛道—赛后感想

1.比赛介绍 中国大学生计算机设计大赛是我国高校面向本科生最早的赛事之一&#xff0c;是全国普通高校大学生竞赛排行榜榜单赛事之一。自2008年开赛至2019年&#xff0c;一直由教育部高校与计算机相关教指委等或独立或联合主办。大赛的目的是以赛促学、以赛促教、以赛促创&…