java实现打砖块游戏算法
作者:李子峰 发布时间:2023-01-28 20:51:06
一个打砖块游戏算法,供大家参考,具体内容如下
这里有一个打砖块游戏:小明面前有很多砖块,每个砖块上有一个字符,小明每击中一个砖块,会产生一个分值,而总分即这些分值总和。砖块上的字符可以是数字,符号或者字母,每个字符的规则如下:
如果击中的砖块上是数字,分数就是数字的值
如果击中的砖块上是’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));
}
}
来源:https://blog.csdn.net/qshn2sky/article/details/72354898


猜你喜欢
- WHY朋友在群里求助一个问题,问题原型是这样的:String str = "{{10.14, 11.24, 44.55, 41.0
- Web Services 可以将应用程序转换为网络应用程序。通过使用 Web Services,您的应用程序可以向全世界发布信息,或提供某项
- Spring容器中的Bean是否线程安全,容器本身并没有提供Bean的线程安全策略,因此可以说Spring容器中的Bean本身不具备线程安全
- 今天我们来编写一个缩放效果的ImageView ,网上有很多人都讲了这些。但有许多人都直接使用了库文件,那么我们今天做的是直接上代码编写一个
- 本文介绍MediaPlayer的使用。MediaPlayer可以播放音频和视频,另外也可以通过VideoView来播放视频,虽然VideoV
- 有很多应用场景,用到了接口动态实现,下面举几个典型的应用:1、mybatis / jpa 等orm框架,可以在接口上加注解进行开发,不需要编
- 先上效果图源码 github.com/woshiwzy/Ca…实现原理:1.继承LinearLayout2.重写onL
- 实现比较两个List之间的差异,包括获取两List的差集,交集,并集(不去重&去重)的API解法和优化解法的解决方案。求差集/**
- 前言作为一个服务端开发感觉一直挺排斥框架这种东西的,总觉得什么实现逻辑都帮你封装在里面了,你只需要配置这配置那个,出了问题也不知道怎么排查,
- java就业前需要掌握的专业技能1.熟练的使用Java语言进行面向对象程序设计,有良好的编程习惯,熟悉常用的Java API,包括集合框架、
- java中不定长参数的使用方法不定长参数方法的语法如下:返回值 方法名(参数类型...参数名称)在参数列表中使用“...”形式定义不定长参数
- 1、@Valid与@Validated的区别1.1 基本区别@Valid:Hibernate validation校验机制@Validate
- 本文实例讲述了C#使用windows服务开启应用程序的方法。分享给大家供大家参考。具体如下:使用windows服务开启应用程序,会遇到如下问
- 本文实例为大家分享了Java实现单向链表反转的具体代码,供大家参考,具体内容如下1、实现代码public class LinkedListT
- yaml介绍YAML(YAML Ain't Markup Language),一种数据序列化格式优点:容易阅读容易与脚本语言交互以数
- 缓存是HTTP协议的一个强大功能,但由于某些原因,它主要用于静态资源,如图像,CSS样式表或JavaScript文件,但是,HTTP缓存不仅
- 在我们对gc中的算法有基本概念理解后,要把算法的理念实现还需要依托实际垃圾收集器的使用。因为光靠一些简单的原理不足以支撑整个程序的运行,在回
- 【1】引用命名空间://System.Net.Socketsusing System.Net.Sockets; // 以太网对象
- 1、@Select注解基本用法@Select注解的目的是为了取代xml中的select标签,只作用于方法上面。下面看一下@Select注解的
- 关于Path之前写的也很多了,例如path绘制线,path绘制一阶,二阶和三阶贝塞尔路径,这些都是path的基本用法。今天我要带大家看的是P