求 C语言 将16进制数,例如“0x00,0xff,0x0f”之类的数转化为2进制数

我这有个程序,0xff可以正确转化,但是比如0x00,0x0f之类的,倒数第二位的0就不认,只认最后一位的0或者f,求高手指教!!!
#include <stdio.h>
#include <string.h>
void main(void)
{
char b[65];
int count[2]={0};
int hex, len, tmp;
int i, j, pos;
scanf("%x", &hex);
tmp = hex;
len = 0;
do { //计算16进制数的位数
tmp >>= 4;
len++;
} while (tmp);
for (i=0; i<len*4; i++)
{
b[i] = ( (hex>>(len*4-1-i))&1 ) + '0';
if (b[i]=='1')
count[1]++;
else
count[0]++;
}
b[i] = '\0';
printf("十六进制数:%X,二进制数:%s\n", hex, b);
printf("0:%2d, 1:%2d\n", count[0], count[1]);
}

手里没分了。。。求帮助!!!

不太明白楼主想要达到什么效果。

16进制前面的0本身不是有效位,最终结果不输出很正常。
你是不是想输入00f,然后输出:十六进制数:00f?这个不太好做吧,你最终输出的时候,又不知道输入的时候前面有多少个0,除非你还统计了输入的16进制前面的0的个数。
二进制的情况类似。追问

不是,我有一个图片的取模软件,取出来之后,就是0x00,0xff,这类的一个数组,它这个数组里,比如0x00转化之后就应该等于00000000这样的2进制数,0xff,转化之后就应该是11111111这样一个2进制数

追答

你要转换的数都是1个字节的?

追问

呃。。。应该是8个字节吧。。。

追答

8个字节那就是8*8=64个二进制比特位了。一个字节8个二进制比特位。

追问

呃。。。这个字节的事我还真不太懂。。不知道跟字节有啥关系。。。现在关键是,我得到的数据是0x00这样的,而且我必须得到00000000这样的转化数据。。。

追答#include <stdio.h>
#include <string.h>
void main(void)
{
    char b[65];
    int count[2]={0};
    int hex;
    int i, j, pos;
    scanf("%x", &hex);
    for (i=0; i<8; i++)
    {
        b[i] = ( (hex>>(8-1-i))&1 ) + '0';
        if (b[i]=='1')
            count[1]++;
        else
            count[0]++;
    }
    b[i] = '\0';
    printf("十六进制数:%02X,二进制数:%s\n", hex, b);
    printf("0:%2d, 1:%2d\n", count[0], count[1]);
}

你试试这个

温馨提示:答案为网友推荐,仅供参考

相关了解……

你可能感兴趣的内容

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 非常风气网