投篮大赛问题

一、题目描述

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

比赛开始时,记录是空白的。你会得到一个记录操作的字符串列表 ops,其中opsi是你需要记录的第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);
    }
}
相关推荐
罗西的思考2 小时前
机器人 / 强化学习】HIL-SERL:人类在环驱动的具身智能进化框架
人工智能·算法·机器学习
CSharp精选营5 小时前
关系型 vs 非关系型:从原理到选型,一文搞定数据库核心分类
数据结构·nosql·关系型数据库·非关系型数据库·技术选型
美团技术团队5 小时前
LongCat 开源 VitaBench 2.0:长期动态智能体基准新标杆
人工智能·算法
洛卡卡了6 小时前
我们在用 AI 写代码时,为什么建议要好好维护 AGENTS.md 呢?
面试·agent·claude
PBitW6 小时前
GPT训练我的第三天,明白了应该咋说满分回答!😕😕😕
前端·javascript·面试
像我这样帅的人丶你还6 小时前
Java 后端详解(四):分页与搜索
java·javascript·后端
她的男孩6 小时前
数据权限为什么不能只靠注解?Forge 的 Mapper 层 SQL 改写源码拆解
java·后端·架构
tntxia7 小时前
Mybatis的日志输入
java
亦暖筑序8 小时前
Java 8老系统Browser Agent实战:三层拦截把AI操作后台变成可审计流程
java·后端·设计模式
用户2986985301411 小时前
Java 实现 Word 文档加密与权限解除
java·后端