投篮大赛问题

一、题目描述

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

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

  1. 整数x-表示本回合新获得分数x
  2. "+" -- 表示本回合新获得的得分是前两次得分的总和。
  3. "D" -- 表示本回合新获得的得分是前一次得分的两倍。
  4. "C" -- 表示本回合没有分数,并且前一次得分无效,将其从记录中移除。

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

二、输入输出描述

输入描述
  • 一行字符串,表示操作序列(用空格分隔)
输出描述
  • 一个整数,表示所有得分总和

三、示例

|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 输入 | 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 |

四、解题思路

1. 核心思想

使用栈(Stack) 这种后进先出 的数据结构,完美匹配操作只影响最近一次 / 两次得分的规则,按顺序处理所有操作,最后累加栈中所有有效得分。

2. 问题本质分析

这是一个带历史回退操作的序列计算问题

  • 所有操作(C/D/+)都只针对最近的得分
  • 需要频繁获取、撤销、计算最近的记录
  • 本质:用栈维护有序的历史记录 + 按规则更新栈 + 最终求和

3. 核心逻辑

  1. 遍历每个操作,只操作栈顶元素(最近得分);
  2. 数字直接入栈;C 弹出栈顶(撤销);D 复制栈顶翻倍;+ 取栈顶两个数求和;
  3. 所有操作完成后,栈中存储的就是全部有效得分
  4. 遍历栈求和,输出结果。

4. 步骤拆解

  1. 输入处理读取一行字符串,按空格分割成操作数组。

  2. 栈初始化创建空栈,用于存储每一轮的有效得分。

  3. 遍历处理操作

    • 数字:入栈
    • C:栈顶出栈(撤销)
    • D:栈顶 ×2 入栈
    • +:取栈顶两个数求和后入栈
  4. 计算总得分遍历栈中所有元素,累加得到最终结果。

  5. 输出总和

五、代码实现

java 复制代码
import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        String[] ops = sc.nextLine().split(" ");
        
        Stack<Integer> stack = new Stack<>();
        
        for (String op : ops) {
            if (op.equals("C")) {
                // 前一次得分无效
                stack.pop();
            } else if (op.equals("D")) {
                // 前一次得分翻倍
                stack.push(stack.peek() * 2);
            } else if (op.equals("+")) {
                // 前两次之和
                int last1 = stack.pop();
                int last2 = stack.peek();
                stack.push(last1);
                stack.push(last1 + last2);
            } else {
                // 数字,直接入栈
                stack.push(Integer.parseInt(op));
            }
        }
        
        // 计算总和
        int sum = 0;
        for (int num : stack) {
            sum += num;
        }
        System.out.println(sum);
    }
}
相关推荐
Dlrb12117 分钟前
C语言-指针数组与数组指针
c语言·数据结构·算法·指针·数组指针·指针数组·二级指针
WL_Aurora9 分钟前
Python 算法基础篇之集合
python·算法
平行侠20 分钟前
A15 工业路由器IP前缀高速检索与内存压缩系统
网络·tcp/ip·算法
hexu_blog26 分钟前
vue+java实现图片批量压缩
java·前端·vue.js
头歌实践平台32 分钟前
Hadoop开发环境搭建
java·大数据·hadoop
Seven971 小时前
一致性Hash算法:如何实现分布式系统中的高效数据分片?
java
摇滚侠1 小时前
IDEA 生成 try catch 快捷键
java·ide·intellij-idea
阿旭超级学得完2 小时前
C++11包装器(function和bind)
java·开发语言·c++·算法·哈希算法·散列表
li星野2 小时前
位运算 & 数学 & 高频进阶九题通关(Python + C++)
c++·python·学习·算法
jerryinwuhan2 小时前
hello算法,简单讲(1)
算法·排序算法