zoukankan      html  css  js  c++  java
  • 中缀表达式转为后缀表达式

    中缀转后缀的有个通俗易懂的方法就是将中缀表达式中的每个运算都加上括号,然后将符号移动到括号后面,再取掉括号即可,
    如:(1 + 2) * 3 + 4 * 5
    先加括号:(((1 + 2) * 3) + (4 * 5))
    移动运算符到括号后面:(((1  2)  + 3) *  (4  5) *) +
    取括号:12+3*45*+

     下面用代码实现哈具体操作

    /**
     * Created With IntelliJ IDEA.
     * Descriptions:
     * 1、定义一个栈stack,用来接收运算符;定义一个char类型数组chars,用于接收输出结果
     * 2、从左到右遍历字符串,遇到字符添加到输chars,遇到运算符栈为空入栈,不为空,
     * 当前运算符A和栈顶运算符B比较,如果A的优先级大于B,那么A入栈,否则A出栈,并添加到chars,B入栈
     * 3、遇到左括号入栈,右括号则进行出栈操作,直到匹配到左括号,出栈结束
     * 4、将栈中剩余元素加入到chars中
     * User:Mr.Du
     * Date:2021/6/19
     * Time:21:22
     */
    /**
         *
         * @param s        输入表达式
         * @param stack   存储操作符和括号
         * @return
         */
        public static String infixToPostFix(String s, Stack<Character> stack){
            int index = 0;
            char[] tmp = s.toCharArray();
            char[] chars = new char[s.length()];
            for(int i = 0;i < s.length();i++){
                //字符就进入输出数组
                if(tmp[i] >= '0' && tmp[i] <= '9'){
                    chars[index++] = tmp[i];
                }else if(tmp[i] == '('){
                    //左括号直接入栈
                    stack.add(tmp[i]);
                }else if(tmp[i] == '+' || tmp[i] == '-'
                            || tmp[i] == '*'
                            || tmp[i] == '/'){
                    //栈为空,直接入栈
                    //不为空,如果当前栈顶元素是(,直接将当前字符入栈
                    //如果栈顶元素的运算符小于当前运算符,则入栈
                    //否则将栈顶元素赋值给输出chars,同时将当前字符入栈
                    if(!stack.isEmpty()){
                        char c = stack.peek();
                        if(c == '('){
                            stack.push(tmp[i]);
                        } else if(getPriority(tmp[i],c)){
                            stack.push(tmp[i]);
                        }else{
                            chars[index++] = c;
                            stack.pop();
                            stack.push(tmp[i]);
                        }
                    }else{
                        stack.push(tmp[i]);
                    }
    
                }else if(tmp[i] == ')'){
                    //如果是右括号,进行出栈操作,直到匹配到左括号为止,将出栈元素赋值给chars
                    char c;
                    while((c = stack.pop()) != '('){
                        chars[index++] = c;
                    }
    
                }
            }
            //将栈中剩余元素赋值给chars
            while(!stack.isEmpty()){
                chars[index++] = stack.pop();
            }
            return String.valueOf(chars);
        }
    
        /**
         * 比较算术运算符大小
         * @param a
         * @param b
         * @return   true代表a的优先级高于b
         */
        public static boolean getPriority(char a,char b){
            if((a == '*' || a == '/') && (b == '+' || b == '-')) return true;
            return false;
        }
     
  • 相关阅读:
    listener中@Autowired无法注入bean的一种解决方法
    PBKDF2加密的实现
    springmvc集成shiro后,session、request是否发生变化
    java加密解密工具类
    springMVC中controller层方法中使用private和public问题
    密码强度正则表达式 – 必须包含大写字母,小写字母和数字,至少8个字符等
    Java判断两个时间相差的天数
    Java中Date、String、Calendar类型之间的转化
    JavaScript前端和Java后端的AES加密和解密(转)
    JS前端加密JAVA后端解密详解
  • 原文地址:https://www.cnblogs.com/du001011/p/14906871.html
Copyright © 2011-2022 走看看