关于32单片机 十进制转换二进制,保存至数组的问题 5C

![图片说明]现在需要将一个十进制数转换为二进制数字并保存在数组里面。二进制数result是经过转换之后的数据,但是在保存在数组里面的时候除了点问题。debug模式下数组显示的都是0,不知道除了什么问题,请各位大神帮帮忙,谢谢

2个回答

n为要转换的目标十进制数,十进制数是int类型,占2或4个字节,-32,768 到 32,767 或 -2,147,483,648 到 2,147,483,647,如果是unsigned int
占2或4个字节,0 到 65,535 或 0 到 4,294,967,295,所以要注意区分是有符号整数还是无符号整数,如果是无符号整数,则以下函数输出正常,如果时有符号整数则要另外考虑:
void fun(int n)
{
int s[32],i = 0;
while(n)
{
s[i++] = n % 2;
n /= 2;
}
for(i = i-1; i >= 0; i--)
{
printf("%d",s[i]);
}
printf("\n");
}

pennytang
pennytang 回复yujunkan: 是不是你的运行环境问题。上面这位兄弟的程序没有问题啊。怎么还是0呢。
接近 2 年之前 回复
yujunkan
yujunkan 试过了,还是都为0
接近 2 年之前 回复

void fun(int num)
{
static u8 s[32],num_long; //设置为静态变量 或者设置为全局变量
u8 i;
// 这里最好给s【32】和num_ling 附初值 初值为0 num_long只是为了记录最后二进制数的长度
为了方便printf的,如果不需要刻意省略
for(i=0;i<32;i++)
{
if((num&0x01)) //每次检测num的最低为 如果为1 则存入s数组为1 如果为0则存入数组为0
{
num_long=i; //num_long记录最后一个为1的位 也就是这个二进制数的长度
s[i]=1
}
else
s[i]=0;

num=num>>1; //每检测一位 num向右右移1位
}
}

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问
相关内容推荐