算法-波兰表达式求值(递归)

package MOOC;

import java.util.Scanner;

/**
问题描述:
 	波兰表达式(前缀表达式)求值 
样例输入: 
	* + 11.0 12.0 + 24.0 35.0 
样例输出: 
	1357.000000
 * 
 * @author Vivinia
 *
 *         2018年1月29日
 */
public class BoLan {
	static String[] str;
	static int i = -1;//设为-1,因为每次调用exp()都会先i++
	public static void main(String[] args) {
		str = new String[20]; // 字符数组
		Scanner input = new Scanner(System.in);
		str = input.nextLine().split(" "); // 输入字符串,转换为字符数组
		input.close();
		System.out.printf("%f", exp());//每调用exp()都会i++
	}

	private static double exp() {
		i++;
		switch (str[i]) {
		case "+":
			return exp() + exp();
		case "-":
			return exp() - exp();
		case "*":
			return exp() * exp();
		case "/":
			return exp() / exp();
		default:
			return Double.parseDouble(str[i]);
		}
	}

}


想说一下Java输入字符串时next()和nextLine()的区别:

1.next()是在输入的一行中,到第一个空格为止,作为本次要输入的字符串,比如我可能输入“I am a girl.”,其实只会存储“I”;

2.nextLine()是在输入的一行中,到回车为止,作为本次输入的字符串(包括空格);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值