【每日一题Day301】LC2337移动片段得到字符串 | 双指针 计分

移动片段得到字符串【LC2337】

给你两个字符串 starttarget ,长度均为 n 。每个字符串 由字符 'L''R''_' 组成,其中:

  • 字符 'L''R' 表示片段,其中片段 'L' 只有在其左侧直接存在一个 空位 时才能向 移动,而片段 'R' 只有在其右侧直接存在一个 空位 时才能向 移动。
  • 字符 '_' 表示可以被 任意 'L''R' 片段占据的空位。

如果在移动字符串 start 中的片段任意次之后可以得到字符串 target ,返回 true ;否则,返回 false

双指针

  • 思路

    如果start进行移动可以的带target,那么将""替换为""后,两个字符串一定相等。由于'L'只能左移,'R'只能右移,那么可以使用双指针 i i i、 j j j定位字符串starttarget中不是''的位置

    • 如果 s t a r t i = = ′ L ′ starti== 'L' starti==′L′,而 i < j i<j i<j时,返回false,因为'L'不能右移
    • 如果 s t a r t i = = ′ R ′ starti== 'R' starti==′R′,而 i > j i>j i>j时,返回false,因为'R'不能左移
  • 实现

    java 复制代码
    class Solution {
        public boolean canChange(String start, String target) {
            if (!start.replaceAll("_", "").equals(target.replaceAll("_", "")))
                return false;
            for (int i = 0, j = 0; i < start.length(); i++) {
                if (start.charAt(i) == '_') continue;
                while (target.charAt(j) == '_')
                    j++;
                if (i != j && (start.charAt(i) == 'L') == (i < j))
                    return false;
                ++j;
            }
            return true;
        }
    }
    
    作者:灵茶山艾府
    链接:https://leetcode.cn/problems/move-pieces-to-obtain-a-string/solutions/1658923/nao-jin-ji-zhuan-wan-pythonjavacgo-by-en-9sqt/
    来源:力扣(LeetCode)
    著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
    • 复杂度
      • 时间复杂度: O ( n ) \mathcal{O}(n) O(n)
      • 空间复杂度: O ( n ) \mathcal{O}(n) O(n)

计分

  • 思路

    • start中的'L'和'R'记为1分,target中'L'和'R'记为-1分
    • 由于L和R不能相互穿透,即L不能移动至R的右边,R不能移动至L的左边,当出现以下情况时返回false
      • 如果 s t a r t i = = ′ L ′ starti== 'L' starti==′L′,而 r > 0 r>0 r>0时,返回false,因为R不能移动至L的右边
      • 如果 s t a r t i = = ′ R ′ starti== 'R' starti==′R′,而 l < 0 l<0 l<0时,返回false,因为L不能移动至R的左边
      • 如果 t a r g e t i = = ′ L ′ targeti== 'L' targeti==′L′,而 r > 0 r>0 r>0时,返回false,因为R不能移动至L的右边
      • 如果 t a r g e t i = = ′ R ′ targeti== 'R' targeti==′R′,而 l < 0 l<0 l<0时,返回false,因为L不能移动至R的左边
      • 如果 l > 0 l>0 l>0或者 r < 0 r<0 r<0时,返回false,start中最左端有L或者最右端有R
  • 实现

    java 复制代码
    class Solution {
        public boolean canChange(String start, String target) {
           int l = 0, r = 0;
           int n = start.length();
           for (int i = 0; i < n; i++){
               if (start.charAt(i) == 'L'){
                   if (r > 0) return false;
                   l++;
               }else if (start.charAt(i) == 'R'){
                   if (l < 0) return false;
                   r++;
               }
               if (target.charAt(i) == 'L'){
                   if (r > 0) return false;
                   l--;
               }else if (target.charAt(i) == 'R'){
                   if (l < 0) return false;
                   r--;
               }
               if (l > 0 || r < 0) return false;
           }
           return l == 0 && r == 0;
           
        }
    }
    • 复杂度
      • 时间复杂度: O ( n ) \mathcal{O}(n) O(n)
      • 空间复杂度: O ( n ) \mathcal{O}(n) O(n)
相关推荐
风筝在晴天搁浅13 小时前
美团 LeetCode 692.前K个高频单词
算法·leetcode·职场和发展
z2005093014 小时前
今日算法(回溯子集)(模版题)
数据结构·算法·leetcode
YL2004042615 小时前
071字符串解码
数据结构·leetcode
z2005093017 小时前
今日算法(回溯子集)
数据结构·算法·leetcode
Hesionberger17 小时前
巧用异或找出唯一数字(多解)
java·数据结构·python·算法·leetcode
菜菜的顾清寒18 小时前
力扣HOT100(47) 二叉树的层序遍历
算法·leetcode·深度优先
sheeta199819 小时前
LeetCode 每日一题笔记 日期:2026.05.31 题目:2126. 摧毁小行星
笔记·算法·leetcode
INGNIGHT19 小时前
984.不含 AAA 或 BBB 的字符串(贪心)
开发语言·算法·leetcode
人道领域20 小时前
【LeetCode刷题日记】538.把二叉搜索树转换为累加树
java·开发语言·后端·算法·leetcode
8Qi820 小时前
LeetCode 76. 最小覆盖子串(Minimum Window Substring)
数据结构·算法·leetcode·滑动窗口·哈希表