欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java實(shí)現(xiàn)打磚塊游戲算法

 更新時(shí)間:2022年05月11日 12:09:01   作者:李子峰  
這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)打磚塊游戲算法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

一個(gè)打磚塊游戲算法,供大家參考,具體內(nèi)容如下

這里有一個(gè)打磚塊游戲:小明面前有很多磚塊,每個(gè)磚塊上有一個(gè)字符,小明每擊中一個(gè)磚塊,會(huì)產(chǎn)生一個(gè)分值,而總分即這些分值總和。磚塊上的字符可以是數(shù)字,符號(hào)或者字母,每個(gè)字符的規(guī)則如下:

  • 如果擊中的磚塊上是數(shù)字,分?jǐn)?shù)就是數(shù)字的值
  • 如果擊中的磚塊上是’D’,分?jǐn)?shù)就是上一個(gè)分值的兩倍
  • 如果擊中的磚塊上是’+’,分?jǐn)?shù)就是前兩個(gè)分值的和
  • 如果擊中的磚塊上是’C’,則取消上一次成績,之后的統(tǒng)計(jì)中不計(jì)算上一次成績

寫一個(gè)算法,為小明的游戲過程計(jì)算總成績。

要求

輸入為兩個(gè)參數(shù),一個(gè)叫blocks,代表一個(gè)字符列表,另一個(gè)叫n,代表列表中字符數(shù)量。
輸出為一個(gè)整數(shù),代表對(duì)給定列表計(jì)算的總成績。

例子

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

計(jì)算過程如下:

第一次打中數(shù)字5,得分5分,總成績5分
第二次打中數(shù)字-2,得分-2分,總成績5 - 2 = 3分
第三次打中數(shù)字4,得分4分,總成績3 + 4 = 7分
第四次打中字母C,上次成績作廢,總成績回到第二次時(shí)的3分
第五次打中字母D,取上次分值-2,乘以2即-4分,總成績?yōu)?1分。注意之前的C把第三次成績?nèi)∠?,不?jì)入計(jì)算,所以再之前的第二次的得分作為上次成績。
第六次打中數(shù)字9,得9分,總成績-1 + 9 = 8分
第七次打中符號(hào)+,得9 - 4 = 5分,總成績8 + 5 = 13分
第八次打中符號(hào)+,得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));
? ? }
}

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • RocketMQ?broker文件清理源碼解析

    RocketMQ?broker文件清理源碼解析

    這篇文章主要為大家介紹了RocketMQ?broker文件清理源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • java實(shí)現(xiàn)多客戶聊天功能

    java實(shí)現(xiàn)多客戶聊天功能

    這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)多客戶聊天功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • 深入學(xué)習(xí)Java同步機(jī)制中的底層實(shí)現(xiàn)

    深入學(xué)習(xí)Java同步機(jī)制中的底層實(shí)現(xiàn)

    在多線程編程中我們會(huì)遇到很多需要使用線程同步機(jī)制去解決的并發(fā)問題,這些同步機(jī)制是如何實(shí)現(xiàn)的呢?下面和小編來一起學(xué)習(xí)吧
    2019-05-05
  • 詳解在Spring-Boot中實(shí)現(xiàn)通用Auth認(rèn)證的幾種方式

    詳解在Spring-Boot中實(shí)現(xiàn)通用Auth認(rèn)證的幾種方式

    這篇文章主要介紹了詳解在Spring-Boot中實(shí)現(xiàn)通用Auth認(rèn)證的幾種方式,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-07-07
  • HDFS的Java API的訪問方式實(shí)例代碼

    HDFS的Java API的訪問方式實(shí)例代碼

    這篇文章主要介紹了HDFS的Java API的訪問方式實(shí)例代碼,分享了相關(guān)代碼示例,小編覺得還是挺不錯(cuò)的,具有一定借鑒價(jià)值,需要的朋友可以參考下
    2018-02-02
  • 利用java和sqlserver建立簡易圖書管理系統(tǒng)的完整步驟

    利用java和sqlserver建立簡易圖書管理系統(tǒng)的完整步驟

    圖書館管理系統(tǒng)是圖書館管理工作中不可缺少的部分,它對(duì)于圖書館的管理者和使用者都非常重要,下面這篇文章主要給大家介紹了關(guān)于利用java和sqlserver建立簡易圖書管理系統(tǒng)的完整步驟,需要的朋友可以參考下
    2022-06-06
  • java 微信小程序code獲取openid的操作

    java 微信小程序code獲取openid的操作

    這篇文章主要介紹了java 微信小程序code獲取openid的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2021-04-04
  • mac下idea的svn密碼記不住的問題及處理方法

    mac下idea的svn密碼記不住的問題及處理方法

    這篇文章主要介紹了mac下idea的svn密碼記不住的問題及處理方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-09-09
  • Java ThreadLocal的詳細(xì)解釋

    Java ThreadLocal的詳細(xì)解釋

    這篇文章主要介紹了快速了解Java中ThreadLocal類,介紹了ThreadLocal 是什么,ThreadLocal的作用,ThreadLocal 原理等相關(guān)內(nèi)容,具有一定參考價(jià)值,需要的朋友可以了解下。
    2021-11-11
  • Java實(shí)現(xiàn)SSH模式加密

    Java實(shí)現(xiàn)SSH模式加密

    這篇文章主要介紹了Java實(shí)現(xiàn)SSH模式加密的相關(guān)資料,需要的朋友可以參考下
    2016-01-01

最新評(píng)論