java实现打砖块游戏算法

 更新时间:2022年05月11日 12:09:01   作者:李子峰  
这篇文章主要为大家详细介绍了java实现打砖块游戏算法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

一个打砖块游戏算法,供大家参考,具体内容如下

这里有一个打砖块游戏:小明面前有很多砖块,每个砖块上有一个字符,小明每击中一个砖块,会产生一个分值,而总分即这些分值总和。砖块上的字符可以是数字,符号或者字母,每个字符的规则如下:

  • 如果击中的砖块上是数字,分数就是数字的值
  • 如果击中的砖块上是’D’,分数就是上一个分值的两倍
  • 如果击中的砖块上是’+’,分数就是前两个分值的和
  • 如果击中的砖块上是’C’,则取消上一次成绩,之后的统计中不计算上一次成绩

写一个算法,为小明的游戏过程计算总成绩。

要求

输入为两个参数,一个叫blocks,代表一个字符列表,另一个叫n,代表列表中字符数量。
输出为一个整数,代表对给定列表计算的总成绩。

例子

输入为:
blocks = [5, -2, 4, C, D, 9, +, +], n = 8
输出为
27

计算过程如下:

第一次打中数字5,得分5分,总成绩5分
第二次打中数字-2,得分-2分,总成绩5 - 2 = 3分
第三次打中数字4,得分4分,总成绩3 + 4 = 7分
第四次打中字母C,上次成绩作废,总成绩回到第二次时的3分
第五次打中字母D,取上次分值-2,乘以2即-4分,总成绩为-1分。注意之前的C把第三次成绩取消了,不计入计算,所以再之前的第二次的得分作为上次成绩。
第六次打中数字9,得9分,总成绩-1 + 9 = 8分
第七次打中符号+,得9 - 4 = 5分,总成绩8 + 5 = 13分
第八次打中符号+,得5 + 9 = 14分,总成绩14 + 13 = 27分

算出总成绩27分

分析过程略,直接上代码:

import java.util.*;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class Solution {
    public static int totalScore(String[] blocks, int n) {
        if(n <= 0) return 0;
        if(blocks.length != n) return 0;
        int sum = 0;
        Integer[] lastScores = new Integer[n];
        Arrays.fill(lastScores, 0);
        List<Integer> scoreList = new ArrayList<>(n);
        for (int i = 0; i < n; i++) {
            if ("C".equals(blocks[i])) {
                sum -= lastScores[1];
                scoreList.remove(lastScores[1]);
                lastScores[1] = scoreList.get(scoreList.size() - 1);
                lastScores[2] = scoreList.get(scoreList.size() - 2);
            } else {
                lastScores[0] = getScore(blocks[i], lastScores[1], lastScores[2]);
                sum += lastScores[0];
                scoreList.add(lastScores[0]);
                lastScores[2] = lastScores[1];
                lastScores[1] = lastScores[0];

            }
        }
        return sum;
    }

    private static int getScore(String mark, int lastScore, int lastScore2) {
        if (null == mark || "".equals(mark)) return 0;
        if (isInteger(mark)) {
            return Integer.parseInt(mark);
        } else if ("D".equals(mark)) {
            return lastScore * 2;
        } else if ("+".equals(mark)) {
            return lastScore + lastScore2;
        }
        return 0;
    }

    private static boolean isInteger(String mark) {
        Pattern pattern = Pattern.compile("^-?[\\d]+$");
        Matcher matcher = pattern.matcher(mark);
        return matcher.matches();
    }

    public static void main(String[] args) {
        String[] blocks = {"5", "-2", "4", "C", "D", "9", "+", "+"};
        int n = blocks.length;
        System.out.println(Solution.totalScore(blocks, n));
    }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • JAVA如何获取jvm和操作系统相关信息

    JAVA如何获取jvm和操作系统相关信息

    这篇文章主要介绍了JAVA获取jvm和操作系统相关信息,使用Java自带的类进行获取系统运行的相关信息,在这整理记录分享一下,需要的朋友可以参考下
    2022-10-10
  • Java 发送http请求上传文件功能实例

    Java 发送http请求上传文件功能实例

    本文通过实例代码给大家介绍了Java 发送http请求上传文件功能,需要的朋友参考下吧
    2017-06-06
  • SpringCloud hystrix服务降级学习笔记

    SpringCloud hystrix服务降级学习笔记

    什么是服务降级?当服务器压力剧增的情况下,根据实际业务情况及流量,对一些服务和页面有策略的不处理或换种简单的方式处理,从而释放服务器资源以保证核心交易正常运作或高效运作
    2022-10-10
  • SpringCloud Zuul实现负载均衡和熔断机制方式

    SpringCloud Zuul实现负载均衡和熔断机制方式

    这篇文章主要介绍了SpringCloud Zuul实现负载均衡和熔断机制方式,具有很好的参考价值,希望对大家有所帮助。
    2021-07-07
  • Spring Boot如何通过java -jar启动

    Spring Boot如何通过java -jar启动

    大家开发的基于Spring Boot 的应用 ,jar形式, 发布的时候,绝大部分都是使用java -jar 启动。本文主要介绍了Spring Boot如何通过java -jar启动,一起来了解一下
    2021-05-05
  • MyBatis @Param注解的实现

    MyBatis @Param注解的实现

    本文主要介绍了MyBatis @Param注解的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-04-04
  • Spring教程之refresh()执行逻辑浅析

    Spring教程之refresh()执行逻辑浅析

    这篇文章主要给大家介绍了关于Spring教程之refresh()执行逻辑的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • logback之如何按日期和大小切分日志

    logback之如何按日期和大小切分日志

    这篇文章主要介绍了logback之如何按日期和大小切分日志问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-06-06
  • jfreechart画折线图的方法

    jfreechart画折线图的方法

    这篇文章主要为大家详细介绍了jfreechart画折线图的方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-06-06
  • Java快速排序案例讲解

    Java快速排序案例讲解

    这篇文章主要介绍了Java快速排序案例讲解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-08-08

最新评论