堆栈解决进制转化问题

进出栈都已经定义好
想用堆栈解决二进制到十进制 但是始终有错误

代码如下
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函数就出不来

http://wenku.baidu.com/link?url=5LFuKoLxNL81_uggpBPV9bIuYMugo6WoJlgATxonNyZO-aoJ7-y1lkuRm_PaeK9rqxplKBPzn81fFEakru7mHzda8ubKPfH76BoGBUdeFku

代码不全很难帮你看。
代码功能归根结底不是别人帮自己看或讲解或注释出来的;而是被自己静下心来花足够长的时间和精力亲自动手单步或设断点或对执行到某步获得的中间结果显示或写到日志文件中一步一步分析出来的。
提醒:再牛×的老师也无法代替学生自己领悟和上厕所!
单步调试和设断点调试(VS IDE中编译连接通过以后,按F10或F11键单步执行,按Shift+F11退出当前函数;在某行按F9设断点后按F5执行停在该断点处。)是程序员必须掌握的技能之一。