gpt4 book ai didi

将整数转换为二进制。我不明白这个功能是如何工作的

转载 作者:太空宇宙 更新时间:2023-11-04 03:22:24 24 4
gpt4 key购买 nike

void int_to_bin_digit(int in, int count, int* out)
{
int mask = 1U << (count-1); // LINE 1
int i;
for (i = 0; i < count; i++)
{
out[i] = (in & mask) ? 1 : 0; // LINE 3 (I don't understand it )
in <<= 1; // LINE 2
}
}

我需要一个将整数转换为二进制的函数。我不知道如何自己制作一个,因为我从未使用过位运算符。我在这里找到了这个,它可以正常工作。

假设我们这样调用函数 int_to_bin_digit(67,8,out)

我知道第 1 行 给掩码值 128 (1000 0000) 而 第 2 行 使 67 (0100 0011) 像这样(不确定这个) )

i=0  (0100 0011) 
-----------
i=1 (1000 0110)
i=2 (0000 1100)
i=3 (0001 1000)
i=4 (0011 0000)
i=5 (0110 0000)
i=6 (1100 0000)
i=7 (1000 0000) (loop stops here )

(0000 0000) (so we never get to this one I guess)

第 3 行是否仅比较第一个 1 并在 ==1 时返回 1,在 !=1 时返回 0?它究竟是如何工作的?

编辑:https://davidzych.com/converting-an-int-to-a-binary-string-in-c/读完这个。我看到我们只比较 in 内的前 1 个和 ma​​sk 内的前 1 个我不明白为什么它不会在每种情况下都只返回 1,因为两个数字都是 != 0。是什么让程序只比较第一位?

最佳答案

是的,你的假设几乎都是正确的。

LINE 1 是第 count 最小位的掩码。 第 3 行 测试您的 in 号码中是否设置了这样的位。术语&代表“按位与”,其中“与”对位进行运算,仅当两个操作数都等于1时才等于1,“按位”表示应用于相应的对操作数的位。 第 2 行 然后继续将 in 中的所有位向左移动,使第 n 位成为之前的 (n-1) 位。

但总而言之,考虑阅读有关按位运算的教程,这将使您作为 C 程序员的生活变得更加轻松。

关于将整数转换为二进制。我不明白这个功能是如何工作的,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44320152/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com