LeetCode——2660. 保龄球游戏的获胜者

通过万岁!!!

  • 题目比较简单,就是给你两个数组,大小为n,分别表示n次投掷保龄球的得分。然后让你按照某种规则计算出最后的总得分,从而判断胜负。计算的规则就是如果出现了10分,那么接下来两轮的分数可以进行*2的操作。
  • 思路:遍历两个数组就好了,然后记录一下10分的位置,每次判断如果当前位置与10分的位置的具体小于2等于2,则这次的比分*2后再加到sum中。并且需要判断是不是要更新下标的位置。但是我写的代码空间复杂度比较高,我进行了优化,取消sum的定义,而是直接放在数组的第0个元素中,但是并没有啥提升。
  • 技巧:数组的遍历

java代码

java 复制代码
class Solution {
    public int isWinner(int[] player1, int[] player2) {
        int tenIdx1 = player1[0] == 10 ? 0 : -3;// 距离最开始要超过2
        int tenIdx2 = player2[0] == 10 ? 0 : -3;
        for (int i = 1; i < player1.length; i++) {
            player1[0] += i - tenIdx1 <= 2 ? 2 * player1[i] : player1[i];
            player2[0] += i - tenIdx2 <= 2 ? 2 * player2[i] : player2[i];
            tenIdx1 = player1[i] == 10 ? i : tenIdx1;
            tenIdx2 = player2[i] == 10 ? i : tenIdx2;
        }
        return player1[0] > player2[0] ? 1 : player1[0] == player2[0] ? 0 : 2;
    }
}
  • 总结:题目不是很难,但是主要是怎么优化一下空间复杂度。
相关推荐
吴声子夜歌1 分钟前
Java——ArrayDeque
java·arraydeque
童先生3 分钟前
华为云、阿里云、AWS签名机制详解! AK/SK + HMAC-SHA256 签名鉴权!
算法·阿里云·华为云·云计算
承渊政道4 分钟前
【贪心算法】(经典实战应用解析(二):最⻓递增⼦序列、递增的三元⼦序列、最⻓连续递增序列、买卖股票的最佳时机、买卖股票的最佳时机II)
数据结构·c++·学习·算法·leetcode·贪心算法·哈希算法
li星野7 分钟前
动态规划十题通关:从爬楼梯到编辑距离(Python + C++)
c++·python·学习·算法·动态规划
NagatoYukee7 分钟前
Spring/SpringMVC/SprongBoot知识复习
java·数据库·spring
栈溢出了10 分钟前
GAT(Graph Attention Network)学习笔记
人工智能·深度学习·算法·机器学习
Tutankaaa10 分钟前
学校知识竞赛怎么组织?从班级到年级的进阶方案
经验分享·学习·算法·职场和发展
qcx2311 分钟前
混合检索+重排序:当前 RAG 精度提升最成熟的工程路径
算法·ai·llm·agent·rag·agentic
洛水水13 分钟前
【力扣100题】42.杨辉三角
算法·leetcode·职场和发展
東隅已逝,桑榆非晚17 分钟前
深⼊理解指针(3)
c语言·数据结构·笔记·算法·排序算法