Leetcode 3694. Distinct Points Reachable After Substring Removal

  • [Leetcode 3694. Distinct Points Reachable After Substring Removal](#Leetcode 3694. Distinct Points Reachable After Substring Removal)
    • [1. 解题思路](#1. 解题思路)
    • [2. 代码实现](#2. 代码实现)

1. 解题思路

这一题思路上就是一个滑动窗口的思路,我们首先计算出终点的位置,然后考察每一个连续长为 k k k的窗口的位移改变量,然后减去对应的改动量即可。

2. 代码实现

给出python代码实现如下:

python 复制代码
class Solution:
    def distinctPoints(self, s: str, k: int) -> int:
        mapping = {"U": [0, 1], "D": [0, -1], "L": [-1, 0], "R": [1, 0]}
        cord = [0, 0]
        for ch in s:
            cord = [x+d for x, d in zip(cord, mapping[ch])]
        ans = set()
        delta = [0, 0]
        for i, ch in enumerate(s):
            delta = [x+d for x, d in zip(delta, mapping[ch])]
            if i-k >= 0:
                delta = [x-d for x, d in zip(delta, mapping[s[i-k]])]
            if i >= k-1:
                ans.add((cord[0]-delta[0], cord[1]-delta[1]))
        return len(ans)

提交代码评测得到:耗时1447ms,占用内存26.8MB。

相关推荐
2401_841495642 小时前
【LeetCode刷题】爬楼梯
数据结构·python·算法·leetcode·动态规划·滑动窗口·斐波那契数列
tang&7 天前
滑动窗口:双指针的优雅舞步,征服连续区间问题的利器
数据结构·算法·哈希算法·滑动窗口
Tisfy7 天前
LeetCode 3652.按策略买卖股票的最佳时机:滑动窗口
算法·leetcode·题解·滑动窗口
橘子真甜~10 天前
C/C++ Linux网络编程14 - 传输层TCP协议详解(保证可靠传输)
linux·服务器·网络·网络协议·tcp/ip·滑动窗口·拥塞控制
he___H11 天前
滑动窗口一题
java·数据结构·算法·滑动窗口
萌>__<新12 天前
力扣打卡每日一题————最小覆盖子串
数据结构·算法·leetcode·滑动窗口·哈希表
拼好饭和她皆失14 天前
高效算法的秘诀:滑动窗口(尺取法)全解析
数据结构·算法·滑动窗口·尺取法
Espresso Macchiato16 天前
Leetcode 3767. Maximize Points After Choosing K Tasks
leetcode medium·leetcode双周赛171·leetcode 3767
Espresso Macchiato16 天前
Leetcode 3765. Complete Prime Number
leetcode medium·leetcode双周赛171·leetcode 3765
xxxxxmy17 天前
同向双指针(滑动窗口)
python·算法·滑动窗口·同向双指针