LeetCode-838 推多米诺

简介: LeetCode-838 推多米诺

来源:力扣(LeetCode)

链接:https://leetcode-cn.com/problems/push-dominoes

题目描述

n 张多米诺骨牌排成一行,将每张多米诺骨牌垂直竖立。在开始时,同时把一些多米诺骨牌向左或向右推。

每过一秒,倒向左边的多米诺骨牌会推动其左侧相邻的多米诺骨牌。同样地,倒向右边的多米诺骨牌也会推动竖立在其右侧的相邻多米诺骨牌。

如果一张垂直竖立的多米诺骨牌的两侧同时有多米诺骨牌倒下时,由于受力平衡, 该骨牌仍然保持不变。

就这个问题而言,我们会认为一张正在倒下的多米诺骨牌不会对其它正在倒下或已经倒下的多米诺骨牌施加额外的力。

给你一个字符串 dominoes 表示这一行多米诺骨牌的初始状态,其中:

dominoes[i] = 'L',表示第 i 张多米诺骨牌被推向左侧,

dominoes[i] = 'R',表示第 i 张多米诺骨牌被推向右侧,

dominoes[i] = '.',表示没有推动第 i 张多米诺骨牌。

返回表示最终状态的字符串。

 

示例 1:

输入:dominoes = "RR.L"
输出:"RR.L"

解释:第一张多米诺骨牌没有给第二张施加额外的力。

示例 2:

 

 

输入:dominoes = ".L.R...LR..L.."
输出:"LL.RR.LLRRLL.."

 

提示:

n == dominoes.length
1 <= n <= 105
dominoes[i] 为 'L'、'R' 或 '.'

解题思路

很需要逻辑的一道题。可以对每一块多米诺牌进行受力分析,首先从右往左遍历,用viRight记录第i张牌受到的向左的力优先级,数字越小说明力越大,如果数字为0则表示没有受到力。然后从左往右依次遍历多米诺牌,判断向右的力的优先级,与向左的力优先级进行比较,对于树立的多米诺牌,更改多米诺牌的状态。

代码展示

 

class Solution {
public:
    string pushDominoes(string dominoes) {
        vector<int> viRight(dominoes.size(), 0);
        int iTemp = 0;
        for (int i = dominoes.size() - 1; i >= 0; i--)
        {
            if (dominoes[i] == 'L')
            {
                iTemp = 1;
            }
            else if (dominoes[i] == 'R')
            {
                iTemp = 0;
            }
            else
            {
                if (iTemp)
                    iTemp++;
            }
            viRight[i] = iTemp;
        }
        iTemp = 0;
        for (int i = 0; i < dominoes.size(); i++)
        {
            if (dominoes[i] == 'R')
            {
                iTemp = 1;
            }
            else if (dominoes[i] == 'L')
            {
                iTemp = 0;
            }
            else
            {
                if (iTemp)
                    iTemp++;
            }
            if (dominoes[i] == '.')
            {
                if (viRight[i]!= 0 && iTemp > viRight[i] || !iTemp && viRight[i])
                {
                    dominoes[i] = 'L';
                }
                else if (iTemp != 0 && iTemp < viRight[i] || !viRight[i] && iTemp)
                {
                    dominoes[i] = 'R';
                }
            }
        }
        return dominoes;
    }
};

运行结果

 

相关文章
|
6月前
leetcode-913:猫和老鼠
leetcode-913:猫和老鼠
84 1
|
5月前
【洛谷 P1002】[NOIP2002 普及组] 过河卒 题解(递归+记忆化搜索)
`NOIP2002`普及组的过河卒问题是一个棋盘路径计数挑战。卒从$(0,0)$出发到$(n,m)$,只能向下或向右移动,马在$(c1,c2)$固定,控制某些点。任务是计算不受马阻挡的路径数。输入是目标和马的位置,输出是路径总数。使用动态规划和记忆化搜索避免重复计算,样例输入$(6,6,3,3)$输出$6$。代码中定义了$f(x,y)$计算$(x,y)$处的路径数,利用边界条件和递推关系计算。
65 0
|
算法 Android开发 C++
LeetCode 周赛上分之旅 #49 再探内向基环树
学习数据结构与算法的关键在于掌握问题背后的算法思维框架,你的思考越抽象,它能覆盖的问题域就越广,理解难度也更复杂。在这个专栏里,小彭与你分享每场 LeetCode 周赛的解题报告,一起体会上分之旅。
90 1
|
6月前
leetcode-838:推多米诺
leetcode-838:推多米诺
42 0
|
算法 Android开发 Kotlin
LeetCode 周赛上分之旅 #42 当 LeetCode 考树上倍增,出题的趋势在变化吗
学习数据结构与算法的关键在于掌握问题背后的算法思维框架,你的思考越抽象,它能覆盖的问题域就越广,理解难度也更复杂。在这个专栏里,小彭与你分享每场 LeetCode 周赛的解题报告,一起体会上分之旅。
116 0
LeetCode 周赛上分之旅 #42 当 LeetCode 考树上倍增,出题的趋势在变化吗
|
算法 Java
N个人站圈报数算法问题
这是一道算法面试题
76 0
|
算法
【过河卒】回溯算法保姆式解题
【过河卒】回溯算法保姆式解题
95 0
|
算法 Android开发 容器
LeetCode 周赛上分之旅 #35 两题坐牢,菜鸡现出原形
学习数据结构与算法的关键在于掌握问题背后的算法思维框架,你的思考越抽象,它能覆盖的问题域就越广,理解难度也更复杂。在这个专栏里,小彭与你分享每场 LeetCode 周赛的解题报告,一起体会上分之旅。
91 0
|
算法 JavaScript 前端开发
日拱算法:双指针解“判断子序列”,除夕快乐~
算法继续,本篇带来的是非常典型的一道题:“判断子序列”,采用的是双指针的解法~
|
定位技术
leetcode每日一题:455. 分发饼干
leetcode每日一题:455. 分发饼干