【发布时间】:2016-05-06 10:05:43
【问题描述】:
我目前正在执行一项任务,我们正在使用 c++ 制作汇编程序。我已经让代码在输入数字时进行区分,并试图让程序将 16 位数组中的相关位更改为所需的二进制数。
问题是在计算幂之后,输入数字的余数和超过它的第一个幂被分配给一个 int,但将它传递回 dec_to_bin() 我收到以下错误。
assembler.cpp:在函数‘void dec_to_bin(int, int*)’中: assembler.cpp:135:32:错误:从‘double (*)(double, double)throw ()’到‘int’的无效转换 [-fpermissive] dec_to_bin(余数,指针);
//*pointer points to an array[16]
void dec_to_bin(int num, int *pointer)
{
//Base cases
if(num == 2)
{
pointer[14] = 1;
return;
}
else if(num == 1)
{
pointer[15] = 1;
return;
}
else
{
int power = 0;
//power function outlined below. The inbuilt pow(a, b) returns a
//double and gave the same problem, so I tried this instead.
while(PowerFunc(2, power) < num)
{
power++;
}
//Problem arises here. remainder is assigned as an int
//Using typeinfo shows it as an int, yet passing it a few lines
//down gives the quoted error.
int remainder = PowerFunc(2, power)-num;
pointer[16-power] = 1;
}
if(remainder == 0)
{
return;
}
else
{
//Line that throws the error. Saying remainder is a double.
dec_to_bin(remainder, pointer);
}
}
//Power function to replace pow(a, b). Not ideal but it works.
int PowerFunc(int number, int powernum)
{
if(powernum == 0)
{
return 1;
}
else if(powernum == 1)
{
return number;
}
else
{
return number * PowerFunc(number, powernum-1);
}
}
老实说,这让我很难过。起初我以为使用 pow(a, b) 并将其分配给 int 只会将小数部分拼接掉,但即使制作我自己的幂函数仍然告诉我我的 int 是双精度数。
【问题讨论】:
-
请考虑逐步计算幂,只需为每次迭代更新它。
标签: c++ error-handling binary