gpt4 book ai didi

c - 尝试用二进制值填充数组并确定最低有效位

转载 作者:行者123 更新时间:2023-11-30 19:33:17 26 4
gpt4 key购买 nike

所以我的任务是创建一个程序,该程序将恰好接受两个参数,第二个参数是整数。我必须将该整数转换为二进制值,然后打印出最低有效“1”位的位置。下面是我当前成功将整数转换为二进制的代码。我想用二进制值填充一个数组,然后从最后一个位置循环并递减计数器,直到遇到“1”,然后通过从当前位置减去数组的总长度来打印出该位的位置数组。

#include <stdio.h>
#include <stdlib.h>

int convert(int);
int main(int argc, char *argv[])
{
int bin;
int n = atoi(argv[2]);

if (argc<2)
{
printf("\nNot Enough Arguments.");
}
if (argc>2)
{
printf("\nToo Many Arguments.");
}
if (argc==2)
{
scanf("%d", &n);
bin = convert(n);
lessbit[] = bin;
}

return 0;
}

int convert(int n)
{
if (n == 0)
{
return 0;
}
else
{
return (n % 2 + 10 * convert(n / 2));
}
}

最佳答案

数字以二进制形式存储在机器中,因此您不需要转换任何内容。

这是一个小演示程序,它将打印从右到左移动的第一个 1 的位置(最低有效位 1 位)。

#include <stdio.h>
#include <stdlib.h>

int main(int arc, char* argv[]) {
if(argc != 2)
exit(EXIT_FAILURE);

int bin = atoi(argv[1]);
unsigned counter = 0;

while(bin % 2 == 0) {
bin >>= 1;
counter++;
}

printf("%u\n", counter);
return 0;
}

此代码打印出以 2 为底的指数。因此,如果数字为 8(二进制为 1000),则输出将是 1 的位置,即 3(因为它位于 2^3 位置)。

关于c - 尝试用二进制值填充数组并确定最低有效位,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46106405/

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