leetcode682-Baseball Game

题目:

你现在是一场采用特殊赛制棒球比赛的记录员。这场比赛由若干回合组成,过去几回合的得分可能会影响以后几回合的得分。

比赛开始时,记录是空白的。你会得到一个记录操作的字符串列表 ops,其中 ops[i] 是你需要记录的第 i 项操作,ops 遵循下述规则:

整数 x - 表示本回合新获得分数 x

"+" - 表示本回合新获得的得分是前两次得分的总和。题目数据保证记录此操作时前面总是存在两个有效的分数。

"D" - 表示本回合新获得的得分是前一次得分的两倍。题目数据保证记录此操作时前面总是存在一个有效的分数。

"C" - 表示前一次得分无效,将其从记录中移除。题目数据保证记录此操作时前面总是存在一个有效的分数。

请你返回记录中所有得分的总和。

示例 1:

输入:ops = ["5","2","C","D","+"]

输出:30

解释:

"5" - 记录加 5 ,记录现在是 [5]

"2" - 记录加 2 ,记录现在是 [5, 2]

"C" - 使前一次得分的记录无效并将其移除,记录现在是 [5].

"D" - 记录加 2 * 5 = 10 ,记录现在是 [5, 10].

"+" - 记录加 5 + 10 = 15 ,记录现在是 [5, 10, 15].

所有得分的总和 5 + 10 + 15 = 30

分析

当前得分的方式有可能是上一次的得分,同时也可能会清空上一次得分,这种很明显适合用先入后出的数据结构,因此栈可以解决这个问题,尤其注意元素是+的时候,先要弹出元素才能取到倒数第二次的分数

同时我们用数组也可以解这个问题,用一个哨兵来标示当前数组的有效位,同时一定要注意最终算总成绩的时候遍历数组不能超过该哨兵(元素是C的时候哨兵会减1,所以哨兵前面的元素才是有效分数)

java 复制代码
import java.util.Deque;
import java.util.LinkedList;
import java.util.Arrays;

public class baseballGame {
	public static void main(String[] args) {
		String[] arr = {"5","2","C","D","+"};
		System.out.println(getScoreArray(arr));
	}
	public static int getScoreArray(String[] arr) {
		int[] count = new int[arr.length];
		int index = 0;
		for(String str : arr) {
			if("D".equals(str)) {
				count[index] = count[index-1] * 2;
				index++;
			} else if("+".equals(str)) {
				count[index] = count[index-1] + count[index-2];
				index++;
			} else if("C".equals(str)) {
				index--;
			} else {
				count[index] = Integer.valueOf(str);
				index++;
			}
		}
		int sum = 0;
		for(int i = 0;i<index;i++) {
			sum = sum + count[i];
		}
		return sum;
	}
	public static int getScore(String[] arr) {
		Deque stack = new LinkedList();
		for(int i = 0;i<arr.length;i++) {
			if(arr[i].charAt(0) == 'C') {
				stack.pop();
			} else if(arr[i].charAt(0) == 'D') {
				int val = (int) stack.peek();
				stack.push(val * 2);
			} else if(arr[i].charAt(0) == '+') {
				int first = (int) stack.peek();
				stack.pop();
				int second = (int) stack.peek();
				stack.push(first);
				stack.push(first+second);
			} else {
				stack.push(Integer.valueOf(arr[i]));
			}
		}
		int sum  = 0;
		while(stack.size() > 0) {
			sum = sum + (int)stack.peek();
			stack.pop();
		}
		return sum;
	}
}
相关推荐
稻草猫.几秒前
Spring AOP
java·后端·spring·java-ee·idea
人工智能培训1 分钟前
样本效率与安全探索的矛盾解析及平衡路径
大数据·人工智能·深度学习·算法·机器学习·知识图谱·故障诊断
Moment2 分钟前
面试爱问底层时,我是怎么读大型前端源码的❓❓❓
前端·javascript·面试
yoso3 分钟前
Claude Code 源码架构深度解析:1884 个文件背后的 AI 编程工具设计哲学
算法·架构
第二只羽毛5 分钟前
C++ 高并发内存池4
java·大数据·linux·c++·算法
有一个好名字7 分钟前
常用注册中心大全(主流 5 个)介绍
java
散峰而望8 分钟前
【数据结构】并查集从入门到精通:基础实现、路径压缩、扩展域、带权,一网打尽
数据结构·c++·算法·github·剪枝·推荐算法
watersink14 分钟前
第7章 软件架构设计
java·开发语言
会编程的土豆16 分钟前
【leetcode hot 100】依旧二叉树
算法·leetcode·职场和发展
ZPC821017 分钟前
MoveIt Servo 控制真实机械臂
人工智能·pytorch·算法·性能优化·机器人