可能有一种聪明的方法可以做到这一点,但无论如何我得到错误:
-(int*)decimalBinary:(int)decimal
{
int i=0;
int *bin;
while (decimal!=0)
{
bin[i]=decimal%2;
decimal=decimal/2;
i++;
}
return bin;
}
在模数线上。为什么? 最新的方法是将它送到阵列?
答案 0 :(得分:0)
声明
int *bin;
为指针留出空间,但不指向对象。在使用之前初始化bin
至关重要
要解决您的问题,您可以在调用函数(bin[4]
)中声明数组int main
,然后将*bin
传递给您的调用函数。
答案 1 :(得分:0)
以下代码改编来自 This answer ,介绍如何以二进制格式打印整数。 将<二进制数字存储到一个int数组 添加到下面的代码中:
#include <stdio.h> /* printf */
#include <stdlib.h> /* strtol */
const char *byte_to_binary(long x);
int main(void)
{
long lVal;
int i, len, array[18];
char buf[18];
{ /* binary string to int */
char *tmp;
char *b = "11010111001010110";
lVal=strtol(b, &tmp, 2); //convert string in "base 2" format to long int
printf("%d\n", lVal);
}
{
printf("%s", byte_to_binary(lVal));
/* byte to binary string */
sprintf(buf,"%s", byte_to_binary(lVal));
}
len = strlen(buf);
for(i=0;i<len;i++)
{ //store binary digits into an array.
array[i] = (buf[i]-'0');
}
getchar();
return 0;
}
const char *byte_to_binary(long x)
{
static char b[17]; //16 bits plus '\0'
b[0] = '\0';
char *p = b;
int z;
for (z = 65536; z > 0; z >>= 1) //2^16
{
*p++ = (x & z) ? '1' : '0';
}
return b;
}