进出栈都已经定义好
想用堆栈解决二进制到十进制 但是始终有错误
代码如下
int inversion(double i)
{
double temp;
Stack S;
setNull(&S);
double sum=0;
for(i=0;i<4;i++)
{
pop(&S);
sum = sum + temp*pow(2,i);
}
return sum;
}
前面pop函数 定义如下
datatype * pop(Stack * S)
{
datatype * temp;
if(isempty(S))
{
printf("Stack Underflow");
return(NULL);
}else
{
S->Top--;
temp=(datatype *)malloc(sizeof(datatype));
* temp=S->elements[S->Top+1];
return temp;
}
}
出栈的值赋给了temp 但是我用temp*pow函数就出不来