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

时间:2017-09-07 23:15:46

标签: c arrays atoi

所以我的任务是创建一个只需要两个参数的程序,第二个是整数。我必须将该整数转换为二进制值,然后打印出最低有效“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 个答案:

答案 0 :(得分:0)

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

这是一个小型演示程序,它将打印从右到左移动的前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位置)。

相关问题