华为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 scores = new ArrayList<>();
        for (int i=0;i

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")
 

你可能感兴趣的:(java,javascript,华为)