| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2070 人关注过本帖
标题:谁知道怎样用堆栈把中缀表达式转为后缀表达式
只看楼主 加入收藏
jy00873757
Rank: 1
等 级:新手上路
帖 子:18
专家分:0
注 册:2006-7-31
收藏
 问题点数:0 回复次数:4 
谁知道怎样用堆栈把中缀表达式转为后缀表达式
搜索更多相关主题的帖子: 堆栈 后缀 表达 
2008-02-13 12:36
roy_guo
Rank: 1
等 级:新手上路
帖 子:107
专家分:0
注 册:2006-4-27
收藏
得分:0 
一年前写的,主要看看核心算法吧。。。细节可能会有点问题
// 1. 将读到的数字依次放入数字栈
// 2. 读出的符号的优先级若不大于符号栈顶元素的优先级,则将栈顶元素弹出参与运算。
// 3. 括号起隔离作用
// 4. 优先级 '#' < +,- < *,/

public class ExpressionCalculation
{
    private String InfixationExpression;
    private myStack1 EStack;
    
    public ExpressionCalculation()
    {
        this("1*2+(3-5/4)*6");    
    }
    
    public ExpressionCalculation( String expression )
    {
        // 表达式后加自定义结束符'#'
        InfixationExpression = expression+'#';
        EStack = new myStack1();
        System.out.print(expression);    
    }
    
    public void ChangeToSuffixExpression()
    {     
        myStack TStack = new myStack();    
        TStack.push("#");
        
        int i = 0;
        String number = "";
        while( i < InfixationExpression.length() )
        {
            if( (InfixationExpression.charAt(i) > 47) && (InfixationExpression.charAt(i) < 58) )
            {
                number += InfixationExpression.charAt(i);    
            }
            else
            {
                if(number != "")
                {
                    EStack.push(Integer.parseInt(number));
                    number = "";
                }
                // 如果符号为+,-,若栈中符号优先级高,则将栈中取出运算
                if( (InfixationExpression.charAt(i) == '+') || (InfixationExpression.charAt(i) == '-') )
                {
                    while( (TStack.top() != "#") && (TStack.top() != "(") )
                    {
                        String t = TStack.top();
                        Calculate(t);
                        TStack.pop();
                    }
                    TStack.push(InfixationExpression.charAt(i)+"");
                }
                //遇结束符,则将符号栈中符号全部取出运算
                else if(InfixationExpression.charAt(i) == '#')
                {
                    while(TStack.getLength() > 0)
                    {
                        String t = TStack.top();
                        Calculate(t);
                        TStack.pop();    
                    }    
                }
                
                else if( (InfixationExpression.charAt(i) == '*') || (InfixationExpression.charAt(i) == '/') )
                {
                    while( (TStack.top() == "*") || (TStack.top() == "/") )
                    {
                        String t = TStack.top();
                        Calculate(t);
                        TStack.pop();
                    }
                    TStack.push(InfixationExpression.charAt(i)+"");
                }
                else if(InfixationExpression.charAt(i) == '(')
                {
                    TStack.push("(");    
                }
                else if(InfixationExpression.charAt(i) == ')')
                {
                    while(!TStack.top().equals("("))
                    {
                        String t = TStack.top();
                        Calculate(t);
                        TStack.pop();
                    }
                    TStack.pop();    
                }
            }
            i ++;
        }
    }
    
    private void Calculate( String op )
    {
        if( op.equals("#") )
        {
            int result = EStack.top();
            System.out.println(" = " + result);
        }
        else
        {
            int num2 = EStack.top();
            EStack.pop();
            int num1 = EStack.top();
            EStack.pop();

            if(op.equals("+"))
            {
                EStack.push( num1+num2 );
            }
            else if(op.equals("-"))
            {
                EStack.push( num1-num2 );    
            }
            else if(op.equals("*"))
            {
                EStack.push( num1*num2 );    
            }
            else if(op.equals("/"))
            {
                EStack.push( num1/num2 );    
            }
            else
            {
                System.out.println("Error!");    
            }            
        }    
    }
    
    public static void main(String args[])
    {
        ExpressionCalculation ec = new ExpressionCalculation();
        ec.ChangeToSuffixExpression();    
    }
}

彪悍的人生不需要解释~~~
2008-02-13 19:56
jy00873757
Rank: 1
等 级:新手上路
帖 子:18
专家分:0
注 册:2006-7-31
收藏
得分:0 
不需要运算,转换就OK了,我想知道多一些算法
2008-02-14 11:32
jy00873757
Rank: 1
等 级:新手上路
帖 子:18
专家分:0
注 册:2006-7-31
收藏
得分:0 
代码不用了,说说思路就OK
2008-02-14 11:32
jy00873757
Rank: 1
等 级:新手上路
帖 子:18
专家分:0
注 册:2006-7-31
收藏
得分:0 
算法越多越好
谢谢各位了
2008-02-14 11:38
快速回复:谁知道怎样用堆栈把中缀表达式转为后缀表达式
数据加载中...
 
   



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

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