C语言中,把一个32位的长整数转化为十六进制字符串,可以采用移位法。这里的移位法是什么,求详细解释

 我来答
雨之默
2017-02-27 · TA获得超过464个赞
知道小有建树答主
回答量:742
采纳率:0%
帮助的人:670万
展开全部
整数在内存里面存储的方式是按二进制存放的,比如:
2,是10;
10,是1010;
你对长整型数字进行移位,左移一位,比如10,移位后就是10100,相当于×2;同理,右移一位,就是101,相当于÷2
这道题移位法处理就是判断数字是否等于0,如果不等于,%16保存余数,再右移4位,直到数字为0为止,得到一个倒序的字符串,然后颠倒过来就行。得到倒序字符串的代码示例。
unsigned int a = 0x457AC8F2;
printf("%x\n",a);
while(a !=0 )
{
printf("%x ",a % 16);
a = a >> 4;
}
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式