LeetCode笔记:Biweekly Contest 108

这篇具有很好参考价值的文章主要介绍了LeetCode笔记:Biweekly Contest 108。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

  • LeetCode笔记:Biweekly Contest 108
    • 1. 题目一
      • 1. 解题思路
      • 2. 代码实现
    • 2. 题目二
      • 1. 解题思路
      • 2. 代码实现
    • 3. 题目三
      • 1. 解题思路
      • 2. 代码实现
    • 4. 题目四
      • 1. 解题思路
      • 2. 代码实现
  • 比赛链接:https://leetcode.com/contest/biweekly-contest-108/

1. 题目一

给出题目一的试题链接如下:

  • 2765. Longest Alternating Subarray

1. 解题思路

这一题我的思路就是使用贪婪算法,不断地考虑每一个点作为起点时可以组成的最长情况即可。

2. 代码实现

给出python代码实现如下:

class Solution:
    def alternatingSubarray(self, nums: List[int]) -> int:
        res, cnt, pre, delta = 0, 0, -1, 1
        for x in nums:
            if x == pre + delta:
                cnt += 1
                delta = -delta
            elif x == pre + 1:
                res = max(res, cnt)
                delta = -1
                cnt = 2
            else:
                res = max(res, cnt)
                delta = 1
                cnt = 1
            pre = x
        res = max(res, cnt)
        return res if res > 1 else -1

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

2. 题目二

给出题目二的试题链接如下:

  • 2766. Relocate Marbles

1. 解题思路

这一题我们只需要记录下每一个时刻所有占据的位置,然后按照题目的描述走一遍流程即可。

2. 代码实现

给出python代码实现如下:

class Solution:
    def relocateMarbles(self, nums: List[int], moveFrom: List[int], moveTo: List[int]) -> List[int]:
        positions = set(nums)
        for x, y in zip(moveFrom, moveTo):
            if x in positions:
                positions.remove(x)
                positions.add(y)
        return sorted(positions)

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

3. 题目三

给出题目三的试题链接如下:

  • 2767. Partition String Into Minimum Beautiful Substrings

1. 解题思路

这一题就是一个动态规划的思路,不断地考察以每一个点作为起点时后续能够构成的合法切分的最小个数然后返回即可。

2. 代码实现

给出python代码实现如下:

class Solution:
    def minimumBeautifulSubstrings(self, s: str) -> int:
        n = len(s)
        
        def is_power5(x):
            while x % 5 == 0:
                x = x // 5
            return x == 1
        
        @lru_cache(None)
        def dp(idx):
            if idx >= n:
                return 0
            if s[idx] == "0":
                return math.inf
            res = math.inf
            x = 0
            for i in range(idx, n):
                x = x * 2 + int(s[i])
                if is_power5(x):
                    res = min(res, 1 + dp(i+1))
            return res
        
        res = dp(0)
        return res if res != math.inf else -1

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

4. 题目四

给出题目四的试题链接如下:

  • 2768. Number of Black Blocks

1. 解题思路

这一题其实整体还是很简单的,就是从黑色格子开始考察,考虑每一个包含黑盒子的block当中含有的黑盒子的个数,然后剩余的就是完全不包含黑盒子的block的个数。

2. 代码实现

给出python代码实现如下:

class Solution:
    def countBlackBlocks(self, m: int, n: int, coordinates: List[List[int]]) -> List[int]:
        cnt = defaultdict(int)
        black_cells = {(x, y) for x, y in coordinates}
        seen = set()
        for x, y in coordinates:
            for i in [-1, 0]:
                for j in [-1, 0]:
                    if 0 <= x+i < m-1 and 0 <= y+j < n-1 and (x+i, y+j) not in seen:
                        s = [1 for a in range(2) for b in range(2) if (x+i+a, y+j+b) in black_cells]
                        cnt[len(s)] += 1
                        seen.add((x+i, y+j))
        cnt[0] = (n-1) * (m-1) - cnt[1] - cnt[2] - cnt[3] - cnt[4]
        return [cnt[i] for i in range(5)]

提交代码评测得到:耗时4015ms,占用内存27.4MB。文章来源地址https://www.toymoban.com/news/detail-540502.html

到了这里,关于LeetCode笔记:Biweekly Contest 108的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • LeetCode笔记:Weekly Contest 354

    LeetCode笔记:Weekly Contest 354 1. 题目一 1. 解题思路 2. 代码实现 2. 题目二 1. 解题思路 2. 代码实现 3. 题目三 1. 解题思路 2. 代码实现 4. 题目四 1. 解题思路 2. 代码实现 比赛链接:https://leetcode.com/contest/weekly-contest-354/ 给出题目一的试题链接如下: 2778. Sum of Squares of Special Elements

    2024年02月16日
    浏览(34)
  • LeetCode笔记:Weekly Contest 357

    LeetCode笔记:Weekly Contest 357 1. 题目一 1. 解题思路 2. 代码实现 2. 题目二 1. 解题思路 2. 代码实现 3. 题目三 1. 解题思路 2. 代码实现 4. 题目四 比赛链接:https://leetcode.com/contest/weekly-contest-357 给出题目一的试题链接如下: 2810. Faulty Keyboard 1. 解题思路 这一题就是按照题目给出的条

    2024年02月14日
    浏览(36)
  • LeetCode笔记:Weekly Contest 359

    LeetCode笔记:Weekly Contest 359 1. 题目一 1. 解题思路 2. 代码实现 2. 题目二 1. 解题思路 2. 代码实现 3. 题目三 1. 解题思路 2. 代码实现 4. 题目四 1. 解题思路 2. 代码实现 比赛链接:https://leetcode.com/contest/weekly-contest-359 给出题目一的试题链接如下: 2828. Check if a String Is an Acronym of

    2024年02月12日
    浏览(35)
  • [LeetCode108双周赛&LeetCode353周赛] 学习用记忆化搜索解决 DP 问题

    参考灵神直播和代码 @cache 装饰器的作用:将传入不同参数得到的函数值存储到缓存,避免下次传递相同参数重复计算结果,可用于解决递归函数重复计算问题,比如递归求斐波那契问题。 https://leetcode.cn/problems/maximum-number-of-jumps-to-reach-the-last-index/ 记忆化搜索 dfs(i) 表示以

    2024年02月13日
    浏览(38)
  • leetcode 108. 将有序数组转换为二叉搜索树

            由数组构造二叉搜索树地问题,本题可以借鉴从中序与后序遍历序列构造二叉树 这道题,这类题 本质就是寻找分割点,分割点作为当前节点,然后递归左区间和右区间 。         下面直接看代码:

    2024年02月16日
    浏览(37)
  • LeetCode108. 将有序数组转换为二叉搜索树

    108. 将有序数组转换为二叉搜索树 一、题目 给你一个整数数组 nums ,其中元素已经按 升序 排列,请你将其转换为一棵 高度平衡 二叉搜索树。 高度平衡 二叉树是一棵满足「每个节点的左右两个子树的高度差的绝对值不超过 1 」的二叉树。 示例 1: 示例 2: 提示: 1 = nums.

    2024年02月11日
    浏览(30)
  • LeetCode 热题 100 JavaScript--108. 将有序数组转换为二叉搜索树

    给你一个整数数组 nums ,其中元素已经按 升序 排列,请你将其转换为一棵 高度平衡 二叉搜索树。 高度平衡 二叉树是一棵满足「每个节点的左右两个子树的高度差的绝对值不超过 1 」的二叉树。 提示: 1 = nums.length = 104 -104 = nums[i] = 104 nums 按 严格递增 顺序排列

    2024年02月14日
    浏览(40)
  • Leetcode 第 108 场双周赛 Problem C 将字符串分割为最少的美丽子字符串(动态规划)

    Leetcode 第 108 场双周赛 Problem C 将字符串分割为最少的美丽子字符串(动态规划) 题目 给你一个二进制字符串 s ,你需要将字符串分割成一个或者多个 子字符串 ,使每个子字符串都是 美丽 的。 如果一个字符串满足以下条件,我们称它是 美丽 的: 它不包含前导 0 。 它是

    2024年02月15日
    浏览(47)
  • LeetCode算法题解|​ 669. 修剪二叉搜索树​、108. 将有序数组转换为二叉搜索树、​538. 把二叉搜索树转换为累加树​

    题目链接:669. 修剪二叉搜索树 题目描述: 给你二叉搜索树的根节点  root  ,同时给定最小边界 low  和最大边界  high 。通过修剪二叉搜索树,使得所有节点的值在 [low, high] 中。修剪树  不应该  改变保留在树中的元素的相对结构 (即,如果没有被移除,原有的父代子代关

    2024年02月06日
    浏览(37)
  • 37. 解数独 - 力扣(LeetCode)

    题目描述 编写一个程序,通过填充空格来解决数独问题。 数独的解法需 遵循如下规则: 数字 1-9 在每一行只能出现一次。 数字 1-9 在每一列只能出现一次。 数字 1-9 在每一个以粗实线分隔的 3x3 宫内只能出现一次。 数独部分空格内已填入了数字,空白格用 ‘.’ 表示。 输入

    2024年01月24日
    浏览(38)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包