IDG | 四则运算表达式计算
分析
首先将中缀表达式转换为后缀表达式(逆波兰式),然后使用栈进行计算。
没有考虑括号、小数。
代码
- import java.util.LinkedList;
- import java.util.List;
- import java.util.Stack;
- public class ExpCal {
- public static double calc(String exp) {
- if (exp == null || exp.length() <= 0) {
- throw new IllegalArgumentException();
- }
- char[] c = exp.toCharArray();
- Stack<Character> s = new Stack<Character>();
- List<String> reversePolishNotation = new LinkedList<String>();
- for (int i = 0; i < c.length; ++i) {
- if (c[i] == '+' || c[i] == '-' || c[i] == '*' || c[i] == '/') {
- while (!s.isEmpty() && compOp(s.peek(), c[i]) >= 0) {
- reversePolishNotation.add(String.valueOf(s.pop()));
- }
- s.push(c[i]);
- } else {
- StringBuilder sb = new StringBuilder();
- while (i < c.length && c[i] >= '0' && c[i] <= '9') {
- sb.append(c[i++]);
- }
- reversePolishNotation.add(sb.toString());
- --i;
- }
- }
- while (!s.isEmpty()) {
- reversePolishNotation.add(String.valueOf(s.pop()));
- }
- Stack<Double> num = new Stack<Double>();
- for (String e : reversePolishNotation) {
- if (e.equals("+")) {
- num.push(num.pop() + num.pop());
- } else if (e.equals("-")) {
- double a = num.pop();
- double b = num.pop();
- num.push(b - a);
- } else if (e.equals("*")) {
- num.push(num.pop() * num.pop());
- } else if (e.equals("/")) {
- double a = num.pop();
- double b = num.pop();
- num.push(b / a);
- } else {
- num.push(Double.parseDouble(e));
- }
- }
- return num.pop();
- }
- private static int compOp(char a, char b) {
- return getPri(a) - getPri(b);
- }
- private static int getPri(char c) {
- switch (c) {
- case '+':
- case '-':
- return 1;
- case '*':
- case '/':
- return 2;
- default:
- return 0;
- }
- }
- public static void main(String[] args) {
- System.out.println(calc("4*3+2*5-8/8-2*6/3+2/1-4"));
- }
- }
IDG | 四则运算表达式计算的更多相关文章
- sql server编写简洁四则运算表达式脚本实现计算批次功能(C#等其它编程语言也能直接用此通用表达式)
问题: 在数据库编程开发中,有时会遇到数据量比较大的情况,如果直接大批量进行添加数据.修改数据.删除数据,就会是比较大的事务,事务日志也比较大,耗时久的话会对正常操作造成一定的阻塞.虽不至于达到删库跑 ...
- WUSTOJ 1208: 计算整数四则运算表达式的结果(Java)
1208: 计算整数四则运算表达式的结果 参考资料 数据结构(C语言版)严蔚敏 吴伟民 编著----表达式求值 题目 简单四则运算.更多内容点击标题. 保证表达式合法. 运算符只包含:加(+),减 ...
- 数据结构课程设计四则运算表达式求值(C语言版)
本系统为四则运算表达式求值系统,用于带小括号的一定范围内正负数的四则运算标准(中缀)表达式的求值.注意事项: 1.请保证输入的四则表达式的合法性.输入的中缀表达式中只能含有英文符号"+ ...
- .NET平台开源项目速览(8)Expression Evaluator表达式计算组件使用
在文章:这些.NET开源项目你知道吗?让.NET开源来得更加猛烈些吧!(第二辑)中,给大家初步介绍了一下Expression Evaluator验证组件.那里只是概述了一下,并没有对其使用和强大功能做 ...
- C# - 二叉树表达式计算
很早以前就写过双栈的表达式计算. 这次因为想深入学一下二叉树,网上都是些老掉牙的关于二叉树的基本操作. 感觉如果就学那些概念,没意思也不好记忆.于是动手写了一个表达式计算的应用例子. 这样学习印象才深 ...
- C#动态表达式计算
C#动态表达式计算 应该有不少人开发过程中遇到过这样的需求,我们直接看图说话: 如上图所示,其中Entity为实体类,其中包括五个属性,该五个属性的值分别来自于数据库查询结果: 用户通过可视化界面进行 ...
- C#动态表达式计算(续2)
上两篇废话太多,这一次我就不多说了,由于代码比较简单,可以直接从https://github.com/scottshare/DynamicExpress.git地址下载. 以下说明一下使用方法: Dy ...
- 栈应用之 后缀表达式计算 (python 版)
栈应用之 后缀表达式计算 (python 版) 后缀表达式特别适合计算机处理 1. 中缀表达式.前缀表达式.后缀表达式区别 中缀表达式:(3 - 5) * (6 + 17 * 4) / 3 17 ...
- C++实现 逆波兰表达式计算问题
C++实现 逆波兰表达式计算问题 #include <iostream> #include <string> using namespace std; class Stack ...
随机推荐
- Netcore 基础之TagHelper知识
饮水思源,来自:http://www.cnblogs.com/liontone 的BLOG中关于taghelper中的内容 概要 TagHelper是ASP.NET 5的一个新特性.也许在你还没有听说 ...
- Mybatis(1、核心配置文件、Properties、Settings、typeAliases...)
Mybatis(1.核心配置文件.Properties.Settings.typeAliases...) 2017年04月23日 22:52:36 阅读数:1527 此章主要介绍sqlMapConfi ...
- STL学习笔记2--list
List --- 双向列表 List是线性列表结构,数据查找需要一个接一个,不能直接得到元素地址,检索时间与目标元素的位置成正比.但是插入数据比较快,可以在任何位置插入数据或者删除数据.list特点是 ...
- BBS-登录
from django.db import models # Create your models here. from django.contrib.auth.models import Abstr ...
- iptables之ipset集群工具
ipset介绍 ipset是iptables的扩展,它允许你创建 匹配整个地址集合的规则.而不像普通的iptables链只能单IP匹配, ip集合存储在带索引的数据结构中,这种结构即时集合比较大也可以 ...
- iOS--app自定义相册--从自定义的相册中获取图片
一.获取单张图片 思路: 1.利用UIImagePickerController可以从系统自带的App(照片\相机)中获得图片 2.设置代理,遵守代理协议 注意这个UIImagePickerContr ...
- mybatis学习(九)——动态sql
MyBatis 的强大特性之一便是它的动态 SQL.可以根据不同条件拼接 SQL 语句. 动态 SQL 元素和使用 JSTL 或其他类似基于 XML 的文本处理器相似.主要由以下几种元素. if wh ...
- [BZOJ4260] Codechef REBXOR (01字典树,异或前缀和)
Description Input 输入数据的第一行包含一个整数N,表示数组中的元素个数. 第二行包含N个整数A1,A2,-,AN. Output 输出一行包含给定表达式可能的最大值. Sample ...
- python:print含有中文的list
Python 的 List 如果有中文的话, 会印出 \xe4\xb8... 等等的编码(如下所示), 要如何印出中文呢? >>> a = ['中文', 'ab']>>& ...
- Best Coder Lotus and Characters
Lotus and Characters 问题描述 Lotus有nn种字母,给出每种字母的价值以及每种字母的个数限制,她想构造一个任意长度的串. 定义串的价值为:第1位字母的价值*1+第2位字母的 ...