火星文计算_100分_A/B复用卷_栈/逻辑分析模拟

火星文计算

题目描述:

已知火星人使用的运算符为#、 $ ,其与地球人的等价公式如下:
  x#y = 2x+3y+4
  x$y = 3*x+y+2
  1、其中x、y是无符号整数
  2、地球人公式按C语言规则计算
  3、火星人公式中,$的优先级高于#,相同的运算符,按从左到右的顺序计算
现有一段火星人的字符串报文,请你来翻译并计算结果。

输入输出描述:

输入描述:

  火星人字符串表达式(结尾不带回车换行)
  输入的字符串说明:字符串为仅由无符号整数和操作符(#、$)组成的计算表达式。
  例如:123#4$5#67$78。
  用例保证字符串中,操作数与操作符之间没有任何分隔符。
  用例保证操作数取值范围为32位无符号整数。
  保证输入以及计算结果不会出现整型溢出。
  保证输入的字符串为合法的求值报文,例如:123#4$5#67$78
  保证不会出现非法的求值报文,例如类似这样字符串:
  #4$5 //缺少操作数
  4$5# //缺少操作数
  4#$5 //缺少操作数
  4 $5 //有空格
  3+4-5*6/7 //有其它操作符
  12345678987654321$54321 //32位整数计算溢出

输出描述:

  根据输入的火星人字符串输出计算结果(结尾不带回车换行)。

示例1:

输入:
	7#6$5#12
输出:
	226
说明:
	7#6$5#12
	=7#(3*6+5+2)#12
	=7#25#12
	=(2*7+3*25+4)#12
	=93#12
	=2*93+3*12+4
	=226

解题思路:

首先,计算问题,涉及到左右操作数和运算符,可以使用栈来存下左操作数,碰到操作符号时,将右操作数弹出来和左操作数运算:
1、因为有优先级,所以优先计算出优先级高的 $ 表达式
2、剩下的表达式必定只剩下 # 表达式,只需要两个操作数两个操作数套用计算公式进行运算即可

代码:

public static void main(String[] args) {
	Scanner scanner = new Scanner(System.in);
	char[] chars = scanner.nextLine().toCharArray();
	Deque<Integer> deque = new ArrayDeque<>();
	int n = chars.length;

	// 先处理 $,遇见 $,就计算出结果。其余转换成数字入队,操作符号默认都是 #,所以没有必要保存 #
	for (int i = 0; i < n; i++) {
		char c = chars[i];
		if (c == '$') {
			// 取出运算符号的右操作数
			int y = chars[++i] - '0';
			while (i + 1 < n && chars[i + 1] != '$' && chars[i + 1] != '#') {
				y = y * 10 + (chars[i + 1] - '0');
				i++;
			}

			int x = deque.pollLast();
			// x$y = 3*x+y+2
			deque.offerLast(3 * x + y + 2);
		} else if(c != '#') {
			// 取出运算符号的操作数(左右操作数都入栈)
			int tmp = c - '0';
			while (i + 1 < n && chars[i + 1] != '$' && chars[i + 1] != '#') {
				tmp = tmp * 10 + (chars[i + 1] - '0');
				i++;
			}
			deque.offerLast(tmp);
		}
	}

	int x = 0;
	// 在处理 #,依次计算
	if (!deque.isEmpty()) {
		// 第一个数是左操作数
		x = deque.pollFirst();
		while (!deque.isEmpty()) {
			// 取出右操作数,并计算:x#y = 2*x+3*y+4
			Integer y = deque.pollFirst();
			x = 2 * x + 3 * y + 4;
		}
	}
	System.out.print(x);
}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值