当前位置: 首页 > article >正文

华为OD机试-投篮大赛-2022Q4 A卷-Py/Java/JS

你现在是一场采用特殊赛制投篮大赛的记录员。这场比赛由若干回合组成,过去几回合的得分可能会影响以后几回合的得分。
比赛开始时,记录是空白的。
你会得到一个记录操作的字符串列表 ops,其中ops[i]是你需要记录的第i项操作,ops遵循下述规则:

整数x-表示本回合新获得分数x
“+” – 表示本回合新获得的得分是前两次得分的总和。
“D” – 表示本回合新获得的得分是前一次得分的两倍。
“C” – 表示本回合没有分数,并且前一次得分无效,将其从记录中移除。
请你返回记录中所有得分的总和。

示例1:

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

Java 代码

import java.util.Scanner;
import java.util.*;
import java.util.stream.Collectors;
import java.math.BigInteger;
 
class Main {
	public static void main(String[] args) {
        // 处理输入
        Scanner in = new Scanner(System.in);
        String[] params = in.nextLine().split(" ");
 
        List<Integer> scores = new ArrayList<>();
        for (int i=0;i<params.length;i++) {
            if (params[i].equals("+")) {
                if (scores.size() < 2) {
                    System.out.println(-1);
                    return;
                }
                scores.add(scores.get(scores.size()-2) + scores.get(scores.size()-1));
            } else if (params[i].equals("D")) {
                if (scores.size() < 1) {
                    System.out.println(-1);
                    return;
                }
                scores.add(2*scores.get(scores.size()-1));
            } else if (params[i].equals("C")) {
                if (scores.size() < 1) {
                    System.out.println(-1);
                    return;
                }
                scores.remove(scores.size() - 1);
            } else {
                scores.add(Integer.parseInt(params[i]));
            }
        }
 
        if (scores.size()==0) {
            System.out.println(0);
        } else {
            System.out.println(scores.stream().reduce(Integer::sum).get());
        }
        
    }
 
}

Python代码

import functools
import sys
 
  
# 处理输入
params = [x for x in input().split(" ")]
 
scores = []
 
flag = False
for i in range(len(params)):
    if (params[i] == "+") :
        if len(scores)<2:
            print(-1)
            flag = True
            break
        scores.append(scores[len(scores)-2] + scores[len(scores)-1])
    elif (params[i] == "D") :
        if len(scores)<1:
            print(-1)
            flag = True
            break
        scores.append(2*scores[len(scores)-1])
    elif (params[i] == "C"):
        if len(scores)<1:
            print(-1)
            flag = True
            break
        scores.pop()
    else:
        scores.append(int(params[i]))
 
if not flag:
    print(sum(scores))

JS代码

function main(input_str) {
    let operations = input_str.split(" ")
    let scores = [];
 
    for (let op of operations) {
        // 判断是否为整数
        if (/^\-?\d+$/.test(op)) {
            scores.push(op - 0);
        } else {
            if (op == "+") {
                if (!scores[scores.length-1] || !scores[scores.length-2]) {
                    console.log(-1)
                    return
                }
                scores.push(scores[scores.length-1] + scores[scores.length-2]);
            } else if (op == "D") {
                if (!scores[scores.length-1]) {
                    console.log(-1)
                    return
                }
                scores.push(scores[scores.length-1] * 2);
            } else if (op == "C") {
                if (!scores[scores.length-1]) {
                    console.log(-1)
                    return
                }
                scores.pop();
            }
        }
            
    }
    if (scores.length==0){
        console.log(0)
    } else {
        console.log(eval(scores.join("+")))
    }
    
}
 
 
main("5 C")
 


http://www.kler.cn/a/7800.html

相关文章:

  • VSCode 在Windows下开发时使用Cmake Tools时输出Log乱码以及CPP文件乱码的终极解决方案
  • 怎样修改el-table主题样式
  • 开放词汇检测新晋SOTA:地瓜机器人开源DOSOD实时检测算法
  • H5通过URL Scheme唤醒手机地图APP
  • 推动多语言语音科技迈向新高度:INTERSPEECH 2025 ML-SUPERB 2.0 挑战赛
  • Matplotlib 直方图:数据可视化基础
  • Windows编程基础
  • 基于SpringBoot+Vue家乡特色推荐系统
  • 获得lazada商品详情 API
  • 4.5-4.6学习总结
  • 详细分析国外主机的性能和稳定性如何?
  • 医疗串口屏有哪些特性?
  • 异步线程池 CompletableFuture 异步编排 【下篇】
  • 高程实验5 素数
  • 制造业短视频标题文案写作技巧
  • 测试碎碎念:selenium
  • sql语法:详解DDL
  • 【云原生】Kubernetes(k8s)之容器的探测
  • 日撸 Java 三百行day14-16
  • 全面带你了解AIGC的风口
  • 软件测试,自学3个月出来就是高薪工作?你以为还是2019年以前?
  • mysql基本语法
  • ST-GCN 论文解读
  • EDAS投稿系统的遇到的问题及解决办法
  • ToBeWritten之物联网Zigbee协议
  • Linux·编译乱序