问题描述
编写一个程序,以字符串方式输入一个前缀表达式,然后计算它的值。输入格式为:“运算符 对象1 对象2”,其中,运算符为“+”(加法)、“-”(减法)、“*”(乘法)或“/”(除法),运算对象为不超过10的整数,它们之间用一个空格隔开。要求:对于加、减、乘、除这四种运算,分别设计相应的函数来实现。
输入格式:输入只有一行,即一个前缀表达式字符串。
输出格式:输出相应的计算结果(如果是除法,直接采用c语言的“/”运算符,结果为整数)。
样例输入
+ 5 2
样例输出
7
思路
- 前缀表达式求值方法:
1.逆序扫描前缀表达式
2.扫描到数字就压入栈中
3.扫描到运算符就弹出栈顶的两个元素运算后将结果入栈
4.循环直到表达式扫描完毕- 程序实现方法:
1.将输入的前缀表达式以字符串形式保存
2.因为有两位运算数,所以将字符串以空格分隔开存入数组
3.创建一个栈类存放操作数
4.逆序遍历数组,遇到数字就压入栈
5.遇到运算符就对栈顶的两个元素进行出栈操作并将结果入栈
6.当数组遍历完毕后栈顶元素即为结果
- 程序实现方法:
代码
import java.util.Scanner;
import java.util.Stack;
public class Prefix {
public static void main(String[] args) {
Scanner input = new Scanner(System.in);
String prefix = input.nextLine();
System.out.println(result(stringToArray