| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1300 人关注过本帖
标题:[求助]逆波兰计算器问题
取消只看楼主 加入收藏
喝茶的小k
Rank: 1
等 级:新手上路
帖 子:87
专家分:0
注 册:2006-7-27
收藏
 问题点数:0 回复次数:2 
[求助]逆波兰计算器问题

这个是源程序,编译通过但好像运行不出结果
大家请看一下,是在vc++ 6.0环境中通过编译的
#include<stdio.h>
#include<stdlib.h> //为了使用atof()函数

#define MAXOP 100  //操作数或运算符的最大长度
#define NUMBER '0'  //标识找到一个数 

int getop(char []);
void push(double);
double pop(void);

int main(void)
{
int type;
double op2;
char s[MAXOP];
while((type=getop(s))!=EOF)
{
switch(type)
{
case NUMBER:
push(atof(s));
break;
case '+':
push(pop()+pop());
break;
case '*':
push(pop()*pop());
break;
case '-':
op2=pop();
push(pop()-op2);
break;
case'/':
op2=pop();
if(op2!=0.0)
push(pop()/op2);
else
printf("error: zero divisor\n");
break;
case'\n':
printf("\t%.8g\n",pop());
break;
default:
printf("error:unknow command%s\n",s);
break;
}
}
return 0;
}

#define MAXVAL 100  //桟val的最大深度
int sp=0;        //下一个空闲桟位置 
double val[MAXVAL];  //值桟

void push(double f)    //push()函数,把f压入到值桟中
{
if(sp<MAXVAL)
val[sp++]=f;
else
printf("error:stack full,can't push %g\n",f);
}

double pop(void)    //弹出并返回桟顶的值
{  
if(sp>0)
return val[--sp];
else
{
printf("error:stack empty\n");
return 0.0;
}
}


#include<ctype.h>

int getop(char s[])
{
int c,i;

while((s[0]=c=getchar())=' '||c=='\t')
;
s[1]='\0';
if(!isdigit(c)&&c!='.')
return c;   //不是数
i=0;
if(isdigit(c))   //收集整数部分
while(isdigit(s[++i]=c=getchar()))
;
if(c=='.')    //收集小数部分
while(isdigit(s[++i]=c=getchar()))
;
s[i]='\0';
if(c!=EOF)
int ungetch(c);
return NUMBER;
}


[此贴子已经被作者于2006-8-2 14:26:52编辑过]

搜索更多相关主题的帖子: 波兰 计算器 
2006-08-02 13:58
喝茶的小k
Rank: 1
等 级:新手上路
帖 子:87
专家分:0
注 册:2006-7-27
收藏
得分:0 

大家看一下我的程序有什么问题啊

编译通过了,怎么运行时不出结果啊


2006-08-03 23:50
喝茶的小k
Rank: 1
等 级:新手上路
帖 子:87
专家分:0
注 册:2006-7-27
收藏
得分:0 

高手指教下啊

我的程序到底由什么问题啊?


2006-08-05 17:38
快速回复:[求助]逆波兰计算器问题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.016877 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved