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

/*

网上很多都是错的,有些甚至题目都没读对

该题的意思是,x可以用多少位的补码表示.

x= -2时,最少用n=2位补码就可以表示了 即 10 这道题求的是n

函数的核心思路:

用左右移位后的结果&一个n位的掩码就得到 x的最少位.移位没造出数字丢失时,x的最少位可以再通过移位还原成本来的x或者-x,

题目的难点:

比如:x=8 二进制补码是1000 此时w=32,n=4,左移32-4=28位得到十六进制补码80000000,此时最高位已经是1了,即已变为负数,再右移32-4=28位得到的十六进制补码fffffff8 即十进制的 -8 此时采用的是取相反数再和原来的x对比.

*/

#include <stdio.h>

int fits_bits(int x,int n);

int main(void)

{

int n = 2;

int x = -2;

printf("f=\t%d\n",fits_bits(x,n));

}

int fits_bits(int x, int n)

{

int b = x;

printf("x\t%32x\n",x);

x<<=(32-n);

printf("x<<\t%32x\n",x);

x>>=(32-n);

printf("x>>\t%32x\n",x);

x=((x&~(-1<<(n)))<<(32-n))>>(32-n);

printf("x back\t%32x\n",x);

return (x==b)||(n==32)||(x==-b);//取相反数这里不知道有没有不完备的问题.

}

相关推荐
股朋公式网13 分钟前
斩仙飞刀、 通达信飞刀 源码
python·算法
不吃橘子的橘猫13 分钟前
NVIDIA DLI 《Build a Deep Research Agent》学习笔记
开发语言·数据库·笔记·python·学习·算法·ai
Xの哲學27 分钟前
Linux CFS 调度器深度解析
linux·服务器·算法·架构·边缘计算
bedynamic34 分钟前
蚁群算法原理及实现
算法·智能算法
Coovally AI模型快速验证1 小时前
当小龙虾算法遇上YOLO:如何提升太阳能电池缺陷检测精度?
人工智能·深度学习·算法·yolo·目标检测·无人机
surtr11 小时前
常见排序模板(冒泡排序,希尔排序,堆排序,归并排序,快速排序)
数据结构·算法·贪心算法·排序算法
fengfuyao9852 小时前
经典MUSIC算法程序以及测角精度与阵元间距、阵元数、信噪比、快拍数等的关系
算法
十八岁讨厌编程2 小时前
【算法训练营 · 补充】LeetCode Hot100(下)
算法·leetcode·职场和发展
一路往蓝-Anbo2 小时前
C语言从句柄到对象 (三) —— 抛弃 Malloc:静态对象池与索引句柄的终极形态
c语言·开发语言·数据结构·stm32·单片机·算法
fantasy_arch3 小时前
SVT-AV1 B帧决策和mini-GOP决策分析
算法·av1