【发布时间】:2017-09-07 23:15:45
【问题描述】:
所以我的任务是创建一个程序,该程序将只接受两个参数,第二个是整数。我必须将该整数转换为二进制值,然后打印出最低有效“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));
}
}
【问题讨论】:
-
int n = atoi(argv[2]);我在这里停止阅读。在检查argc的值之前使用argv[2]?那只是自找麻烦。我还应该补充一点:整数已经是二进制的...... -
@J.Clark 整数已经以二进制形式存储。
-
BTW 在使用
argv之前检查argc是必要的。lessbit[] = bin;:lessbit?