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。

相关推荐
Espresso Macchiato5 小时前
Leetcode 3698. Split Array With Minimum Difference
leetcode medium·分类讨论·leetcode周赛469·leetcode 3698
Espresso Macchiato1 天前
Leetcode 3695. Maximize Alternating Sum Using Swaps
并查集·leetcode hard·dsu·uf·leetcode 3695·leetcode双周赛166
Brookty11 天前
【算法】滑动窗口(一)-长度最小的子数组
java·学习·算法·力扣·滑动窗口
伟大的车尔尼20 天前
滑动窗口题目:删除子数组的最大得分
滑动窗口
递归尽头是星辰21 天前
双指针与滑动窗口算法精讲:从原理到高频面试题实战
算法·双指针·滑动窗口·子串/子数组问题
ゞ 正在缓冲99%…23 天前
leetcode438.找到字符串中所有字母异位词
leetcode·滑动窗口
3Cloudream25 天前
LeetCode 003. 无重复字符的最长子串 - 滑动窗口与哈希表详解
算法·leetcode·字符串·双指针·滑动窗口·哈希表·中等
HUIMU_1 个月前
DAY20-新世纪DL(DeepLearning/深度学习)战士:终(目标检测/YOLO)3
深度学习·yolo·目标检测·滑动窗口·非极大值抑制·交并比·bouding box
Espresso Macchiato1 个月前
Leetcode 3665. Twisted Mirror Path Count
动态规划·leetcode medium·leetcode 3665·leetcode双周赛164