Java实现简单四则运算

2024-09-03 01:08

本文主要是介绍Java实现简单四则运算,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

工作之余,突然想用java实现一下四则运算,经过简单的构思,很快就有了思路,就完成了一个简单版本。

 

经过慎重考虑,觉得使用栈还是要比数组或者List容易对符号和数字进行控制。

我使用两个栈,分别保存数字和符号,然后判断当前符号和前一个符号的运算级别,来决定是否进行一次弹栈运算(就是挨着前一个运算符号的两个数,是不是有必要进行一次运算)。

经过简单的测试,标准的四则运算,在下面代码是没有问题的。

如果再加括号,那就是在这个基础上,添加去括号的流程就可以,等那天有时间了,再完善吧。

 

所有源码如下:

package com.rq.spring.main;import java.util.Stack;
/*** 使用栈完成的简单四则运算,不带有任何括号* 测试时,请输入标准的四则运算式* 待优化的地方很多,各位大神,多提意见* @author 任强**/
public class TestStackSimpleOperation {public static void main(String[] args) {//简单语法// Stack<String> stack = new Stack<>();//创建一个栈,字符串类型// // stack.push("a");//压栈// stack.push("b");// stack.push("c");// // while(!stack.empty()){//判断是否为空// String s = stack.pop();//弹栈// System.out.println(s);// }//另一种遍历栈的方法// Iterator<String> it = stack.iterator();// while(it.hasNext()){// String s = it.next();// System.out.println(s);// }//测试自己编写的方法// System.out.println(simpleOperation("1+2+3*5+4*6-7/7+1"));//42// System.out.println(simpleOperation("1*2*3*4*5*6+1+2*5+9*6+9"));//794// System.out.println(simpleOperation("5+6/3*8-9+45*67+95/5+8-85"));//2969System.out.println(simpleOperation("1+2+3-4+5*6-7+8-9*6/2/1+99/33*55-951"));//-780}/*** 简单四则运算* @param equation 四则运算式* @return 运算结果*/public static int simpleOperation(String equation){Stack<Integer> nums = new Stack<>();//保存运算数字的栈Stack<String> symbols = new Stack<>();//保存运算符号的栈while(equation != null && equation.length() > 0){int symIndex = getLastIndex(equation);if(symIndex == -1){//表示已经到了运算式的结尾,需要返回结果了int num = Integer.valueOf(equation);int r = getResult(num, symbols.pop(), nums.pop());while(!symbols.empty()) {r = getResult(r, symbols.pop(), nums.pop());}return r;}int num = Integer.valueOf(equation.substring(0, symIndex));nums.push(num);String sym = equation.substring(symIndex, symIndex + 1);//完成计算流程String lastSym = symbols.empty() ? null : symbols.peek();//获取前一个运算符//前一个运算符存在,且它的等级是不小于当前运算符,就进行一次运算,//把数字栈中的后两个元素弹栈操作,使用前一个运算符完成计算//使用while的原因是可能在符号栈中需要继续进行往前一步的运算while(lastSym != null && getLevel(lastSym) >= getLevel(sym)){nums.push(getResult(nums.pop(), symbols.pop(), nums.pop()));lastSym = symbols.empty() ? null : symbols.peek();}symbols.push(sym);equation = equation.substring(symIndex + 1);}return 0;}//计算结果,因为是弹栈操作,所有后弹出的数字在运算符前面private static int getResult(int a, String sym, int b){switch(sym){case "+" : return b + a;case "-" : return b - a;case "*" : return b * a;default : return b / a;}}//运算符等级,等级越高需要越先完成计算private static int getLevel(String sym){return sym.equals("+") || sym.equals("-") ? 1 : 2 ;}//最接近运算式起始的符号位置,用来确定马上要参与运算的数字和该数字之后的运算符private static int getLastIndex(String equation){int addIndex = equation.indexOf("+");int symIndex = -1;if(addIndex > -1){symIndex = addIndex;}int subIndex = equation.indexOf("-");if(subIndex > -1 && (symIndex == -1 || symIndex > subIndex)){symIndex = subIndex;}int mulIndex = equation.indexOf("*");if(mulIndex > -1 && (symIndex == -1 || symIndex > mulIndex)){symIndex = mulIndex;}int divIndex = equation.indexOf("/");if(divIndex > -1 && (symIndex == -1 || symIndex > divIndex)){symIndex = divIndex;}return symIndex;}
}

 

这篇关于Java实现简单四则运算的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1131586

相关文章

Java中流式并行操作parallelStream的原理和使用方法

《Java中流式并行操作parallelStream的原理和使用方法》本文详细介绍了Java中的并行流(parallelStream)的原理、正确使用方法以及在实际业务中的应用案例,并指出在使用并行流... 目录Java中流式并行操作parallelStream0. 问题的产生1. 什么是parallelS

C++中unordered_set哈希集合的实现

《C++中unordered_set哈希集合的实现》std::unordered_set是C++标准库中的无序关联容器,基于哈希表实现,具有元素唯一性和无序性特点,本文就来详细的介绍一下unorder... 目录一、概述二、头文件与命名空间三、常用方法与示例1. 构造与析构2. 迭代器与遍历3. 容量相关4

Java中Redisson 的原理深度解析

《Java中Redisson的原理深度解析》Redisson是一个高性能的Redis客户端,它通过将Redis数据结构映射为Java对象和分布式对象,实现了在Java应用中方便地使用Redis,本文... 目录前言一、核心设计理念二、核心架构与通信层1. 基于 Netty 的异步非阻塞通信2. 编解码器三、

C++中悬垂引用(Dangling Reference) 的实现

《C++中悬垂引用(DanglingReference)的实现》C++中的悬垂引用指引用绑定的对象被销毁后引用仍存在的情况,会导致访问无效内存,下面就来详细的介绍一下产生的原因以及如何避免,感兴趣... 目录悬垂引用的产生原因1. 引用绑定到局部变量,变量超出作用域后销毁2. 引用绑定到动态分配的对象,对象

SpringBoot基于注解实现数据库字段回填的完整方案

《SpringBoot基于注解实现数据库字段回填的完整方案》这篇文章主要为大家详细介绍了SpringBoot如何基于注解实现数据库字段回填的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解... 目录数据库表pom.XMLRelationFieldRelationFieldMapping基础的一些代

一篇文章彻底搞懂macOS如何决定java环境

《一篇文章彻底搞懂macOS如何决定java环境》MacOS作为一个功能强大的操作系统,为开发者提供了丰富的开发工具和框架,下面:本文主要介绍macOS如何决定java环境的相关资料,文中通过代码... 目录方法一:使用 which命令方法二:使用 Java_home工具(Apple 官方推荐)那问题来了,

Java HashMap的底层实现原理深度解析

《JavaHashMap的底层实现原理深度解析》HashMap基于数组+链表+红黑树结构,通过哈希算法和扩容机制优化性能,负载因子与树化阈值平衡效率,是Java开发必备的高效数据结构,本文给大家介绍... 目录一、概述:HashMap的宏观结构二、核心数据结构解析1. 数组(桶数组)2. 链表节点(Node

Java AOP面向切面编程的概念和实现方式

《JavaAOP面向切面编程的概念和实现方式》AOP是面向切面编程,通过动态代理将横切关注点(如日志、事务)与核心业务逻辑分离,提升代码复用性和可维护性,本文给大家介绍JavaAOP面向切面编程的概... 目录一、AOP 是什么?二、AOP 的核心概念与实现方式核心概念实现方式三、Spring AOP 的关

详解SpringBoot+Ehcache使用示例

《详解SpringBoot+Ehcache使用示例》本文介绍了SpringBoot中配置Ehcache、自定义get/set方式,并实际使用缓存的过程,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录摘要概念内存与磁盘持久化存储:配置灵活性:编码示例引入依赖:配置ehcache.XML文件:配置

Java 虚拟线程的创建与使用深度解析

《Java虚拟线程的创建与使用深度解析》虚拟线程是Java19中以预览特性形式引入,Java21起正式发布的轻量级线程,本文给大家介绍Java虚拟线程的创建与使用,感兴趣的朋友一起看看吧... 目录一、虚拟线程简介1.1 什么是虚拟线程?1.2 为什么需要虚拟线程?二、虚拟线程与平台线程对比代码对比示例:三