注意: 数据在计算机中存的二进制 ,其实就是补码!
假设:输入一个数num,
num & 0x01; //让num和1相与
这时候和1相与的 就是num的补码。
所以,想要显示一个数的补码,只要对数进行位运算操作,把它的二进制数拿出来就ok
#include<stdio.h>int main()
{int num = 0;scanf("%d",&num);char bits[32] = {}; //对于int类型而言,有32个字节,最好就是存入数组中for(int i=0;i<32;i++){bits[i] = num & 1; //与1就是显示它本身,此时的num是补码,把第i位存入数组num = num >> i; //num的补码 往右移i位}
}
循环结束后,num的补码就倒着存入数组,所以需要从后往前输出。接上:
for(i=31;i>=0;i--)
{printf("%hhd ",bits[i]);
}
本文发布于:2024-02-01 22:36:15,感谢您对本站的认可!
本文链接:https://www.4u4v.net/it/170679817739884.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |