设为首页 加入收藏

TOP

计算器思想-中缀表达式转化为后缀表达式(二)
2023-09-23 15:44:29 】 浏览:118
Tags:计算器 后缀表
k.pop()); } stack.pop(); } // * 2.遇到操作符 else { // * 2.1当栈为空,或栈顶元素为(,直接放入到栈中 // * 2.3当优先级小于等于栈顶元素,将栈顶元素出栈放入到集合中,再和栈顶元素比较 while (stack.size() != 0 && !judgeOperator(value, stack.peek())) { list.add(stack.pop()); } // * 2.2当优先级比栈顶元素高时,直接进栈 stack.push(value); } } // * 4.最后将栈顶元素依次弹出 while (!stack.empty()) { list.add(stack.pop()); } System.out.println(list); return list; } /** * 将运算字符切分切分成集合 * @param str 待切分字符串 * @return ArrayList<String> 被切分之后的字符串集合 */ private static ArrayList<String> cutString(String str) { String[] arr = new String[str.length()-1]; // 为字符串数组赋初值 for (int i = 0; i < arr.length; i++) { arr[i] = ""; } int index = 0; arr[index] = String.valueOf(str.charAt(0)); for (int i = 1; i < str.length(); i++) { // 1.是数值放入 if (Character.isDigit(str.charAt(i))) { // 1.1并看其起一个数据是不是也数值,是数值,将其前一个数据*10+本身 if (arr[index].matches("\\d+")) { arr[index] = String.valueOf(Integer.parseInt(arr[index]) * 10 + Integer.parseInt(String.valueOf(str.charAt(i)))); } else { arr[++index] = String.valueOf(str.charAt(i)); } } else { // 2.不是数值,直接加入到集合中 arr[++index] = String.valueOf(str.charAt(i)); } } // 去除null ArrayList<String> list = removeNull(arr); return list; } /** * 将字符串数组中为空的元素去除 * @param arr 字符串数组 * @return 去除控制的字符串集合 */ private static ArrayList<String> removeNull(String[] arr) { ArrayList<String> list = new ArrayList<>(); for (String s : arr) { if (!"".equals(s)) { list.add(s); } } return list; } /** * 比较新旧操作符的权重,判断是存放还是取出 * @param s1 新的操作符 * @param s2 旧的操作符 * @return 新旧操作符的权重比较 */ private static boolean judgeOperator(String s1, String s2) { int num1 = 0, num2 = 0; switch (s1) { case "+": case "-": num1 = 1; break; case "*": case "/": num1 = 2; break; } switch (s2) { case "+": case "-": num2 = 1; break; case "*": case "/": num2 = 2; break; } // 判断新旧操作符的优先级 if (num1 > num2) { return true; } return false; } }

小数算式运算

小数运算要考虑小数点,相对于整数要比较的复杂
在获取娴熟时,需要对小数点的位置进行判断,对小数点右边的数据进行处理

package com.prettyspider.calculate;

import java.util.*;


/**
 * @author prettyspider
 * @ClassName CalcInt
 * @description: 传入整数运算字符串,计算其数值
 * @date 2023/9/11 6:21
 * @Version V1.0
 */

public class CalcDouble {
    /**
     * 中缀表达式转化成后缀表达式
     * <p>
     * 1.遇到操作数直接放入到集合中
     * 2.遇到操作符
     * 2.1当栈为空,或栈顶元素为(,直接放入到栈中
     * 2.2当优先级比栈顶元素高时,直接进栈
     * 2.3当优先级小于等于栈顶元素,将栈顶元素出栈放入到集合中,再和栈顶元素比较
     * 3.遇到左右括号
     * 3.1如果为左括号,直接加入栈
     * 3.2如果为右括号,依次将栈顶元素弹出,直到左括号,并将左括号弹出
     * 4.最后将栈顶元素依次弹出
     */
    public static void main(String[] args) {
        // 要传入的运算字符串
        String s = "10.32*3.23+2.234";
        // 中缀表达式转化成后缀表达式
        List<String> list = inToPastExpression(s);
        // 计算
        double number = calc(list);
        System.out.println("计算的数值为"+number);
    }


    /**
     * 计算后缀表达式
     * @param list 后缀表达式集合
     * @return 传入的整数运算字符串的计算数值
     */
    private static double calc(List<String> list) {
        // 创建栈,用于记录数据
        Stack<String> stack = new Stack<>();
        for (String s : list) {
            // 1.放入 当是数值时,直接放入栈中
            if (s.matches("(\\d|\\.)+")) {
                stack.push(s);
            } else {
                // 2.去除 当是运算符时,再栈中取出两个数,进行运算,并将运算之后的结果放入到栈中
                double num1, num2;
                switch (s) {
                    case "+":
                        num1 = Double.valueOf(stack.pop());
                        num2 = Double.valueOf(stack.pop());
                        stack.push(String.valueOf(num2 + num1));
                        br
首页 上一页 1 2 3 下一页 尾页 2/3/3
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇京东一面:分布式 ID 生成方案怎.. 下一篇25届实习/秋招-java面试-JavaSe面..

最新文章

热门文章

Hot 文章

Python

C 语言

C++基础

大数据基础

linux编程基础

C/C++面试题目