我这有个程序,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]);
}
你试试这个