在 Java 中计算数学表达式
使用堆栈评估数学表达式是最常见和有用的选项之一。
Stack 有两种标准方法,pop()
和 push()
,用于从堆栈中放入和获取操作数或运算符。pop()
方法删除表达式的顶部元素,而 push()
方法将一个元素放在堆栈顶部。
在 Java 中计算数学表达式
这是一个用 Java 计算数学表达式的示例。此代码遵循正确的 DMAS 规则,具有以下优先级:除法、乘法、加法和减法。
你可以给它任何数学表达式作为输入,但要确保表达式仅包含以下四种运算(加法、乘法、除法和减法)。
示例代码:
package evaluateexpression;
import java.util.Scanner;
import java.util.Stack;
public class EvaluateExpression {
public static void main(String[] args){
Scanner scan = new Scanner(System.in);
// Creating stacks for operators and operands
Stack<Integer> operator = new Stack();
Stack<Double> value = new Stack();
// Let's create some temparory stacks for operands and operators
Stack<Integer> tmpOp = new Stack ();
Stack<Double> tmpVal = new Stack ();
// Enter an arthematic expression
System.out.println("Enter expression");
String input = scan.next();
System.out.println("The type of the expression is "+((Object)input).getClass().getSimpleName());
input = "0" + input;
input = input.replaceAll("-","+-");
// In the respective stacks store the operators and operands
String temp = "";
for (int i = 0;i < input.length();i++){
char ch = input.charAt(i);
if (ch == '-')
temp = "-" + temp;
else if (ch != '+' && ch != '*' && ch != '/')
temp = temp + ch;
else{
value.push(Double.parseDouble(temp));
operator.push((int)ch);
temp = "";
}
}
value.push(Double.parseDouble(temp));
// Create a character array for the operator precedence
char operators[] = {'/','*','+'};
/* Evaluation of expression */
for (int i = 0; i < 3; i++){
boolean it = false;
while (!operator.isEmpty()){
int optr = operator.pop();
double v1 = value.pop();
double v2 = value.pop();
if (optr == operators[i]){
// if operator matches evaluate and store it in the temporary stack
if (i == 0){
tmpVal.push(v2 / v1);
it = true;
break;
}
else if (i == 1){
tmpVal.push(v2 * v1);
it = true;
break;
}
else if (i == 2){
tmpVal.push(v2 + v1);
it = true;
break;
}
}
else{
tmpVal.push(v1);
value.push(v2);
tmpOp.push(optr);
}
}
// pop all the elements from temporary stacks to main stacks
while (!tmpVal.isEmpty())
value.push(tmpVal.pop());
while (!tmpOp.isEmpty())
operator.push(tmpOp.pop());
// Iterate again for the same operator
if (it)
i--;
}
System.out.println("\nResult = "+value.pop());
}
}
输出:
Enter expression
2+7*5-3/2
The type of the expression is String
Result = 35.5
正如你在上述代码的输出中看到的,表达式 2+7*5-3/2
作为输入给出。程序计算结果为 35.5
。
它首先划分 3/2 = 1.5
,因为在 DMAS 规则中,划分具有最高优先级。然后乘法部分计算为 7*5 = 35
。
接下来,我们有 2+35 = 37
的加法,表达式的最后一部分是减法,即 37 -1.5 = 35.5
。
相关文章
如何在 Java 中延迟几秒钟的时间
发布时间:2023/12/17 浏览次数:217 分类:Java
-
本篇文章主要介绍如何在 Java 中制造程序延迟。本教程介绍了如何在 Java 中制造程序延时,并列举了一些示例代码来了解它。
如何在 Java 中把 Hashmap 转换为 JSON 对象
发布时间:2023/12/17 浏览次数:187 分类:Java
-
它描述了允许我们将哈希图转换为简单的 JSON 对象的方法。本文介绍了在 Java 中把 Hashmap 转换为 JSON 对象的方法。我们将看到关于创建一个 hashmap,然后将其转换为 JSON 对象的详细例子。
如何在 Java 中按值排序 Map
发布时间:2023/12/17 浏览次数:171 分类:Java
-
本文介绍了如何在 Java 中按值对 Map 进行排序。本教程介绍了如何在 Java 中按值对 Map
进行排序,并列出了一些示例代码来理解它。
如何在 Java 中打印 HashMap
发布时间:2023/12/17 浏览次数:192 分类:Java
-
本帖介绍了如何在 Java 中打印 HashMap。本教程介绍了如何在 Java 中打印 HashMap 元素,还列举了一些示例代码来理解这个主题。
在 Java 中更新 Hashmap 的值
发布时间:2023/12/17 浏览次数:146 分类:Java
-
本文介绍了如何在 Java 中更新 HashMap 中的一个值。本文介绍了如何在 Java 中使用 HashMap 类中包含的两个方法-put() 和 replace() 更新 HashMap 中的值。
Java 中的 hashmap 和 map 之间的区别
发布时间:2023/12/17 浏览次数:79 分类:Java
-
本文介绍了 Java 中的 hashmap 和 map 接口之间的区别。本教程介绍了 Java 中 Map 和 HashMap 之间的主要区别。在 Java 中,Map 是用于以键值对存储数据的接口,
在 Java 中获取用户主目录
发布时间:2023/12/17 浏览次数:218 分类:Java
-
这篇文章向你展示了如何在 Java 中获取用户主目录。本教程介绍了如何在 Java 中获取用户主目录,并列出了一些示例代码以指导你完成该主题。
Java 中 size 和 length 的区别
发布时间:2023/12/17 浏览次数:179 分类:Java
-
这篇文章教你如何知道 Java 中大小和长度之间的区别。本教程介绍了 Java 中大小和长度之间的区别。我们还列出了一些示例代码以帮助你理解该主题。
Java 中的互斥锁
发布时间:2023/12/17 浏览次数:111 分类:Java
-
了解有关 Java 中互斥锁的一切,在计算机科学领域,互斥或互斥被称为并发控制的属性。每台计算机都使用称为线程的最小程序指令序列。有一次,计算机在一个线程上工作。为了更好地理解,