2022-11-20 每日打卡:Leetcode第 320 场周赛

news2025/1/10 10:12:42

2022-11-20 每日打卡:Leetcode第 320 场周赛

题解主要参考:https://www.bilibili.com/video/BV1A3411f7H3/?spm_id_from=333.999.0.0&vd_source=6fcf135348bf11256bcd756a96851533

6241. 数组中不等三元组的数目

在这里插入图片描述

对于排列组合问题,关注“顺序是否影响结果”。这个题目的注意看起来是说顺序会影响结果,但实际上(0,2,4)和(2,0,4)指的就是同一个三元组,而该三元组只能加进去一次。
所以我们就可以【排序+统计】,对于每个相同的数字,比他小的可以选一个,比他大的可以选一个。复杂度O(nlogn)。

class Solution:
    def unequalTriplets(self, nums: List[int]) -> int:
        nums.sort()
        ans = start = 0
        for i in range(len(nums)-1):
            if nums[i]!=nums[i+1]:
                # start 前面可以选的数
                # (i-start+1) 重复的段
                # (len(nums)-1-i) 后面可选的数
                ans += start * (i-start+1) * (len(nums)-1-i)
                start = i+1
        return ans

6242. 二叉搜索树最近节点查询

在这里插入图片描述

  • 最大的是遍历到不能遍历,右走的分支最近的
  • 最小的是遍历到不能遍历,左走的分支最近的
  • 不要每个结点都去遍历,使用dfs+二分可以快速查找!
class Solution:
    def closestNodes(self, root: Optional[TreeNode], queries: List[int]) -> List[List[int]]:
        nodes = []
        def dfs(node):
            if not node:
                return
            dfs(node.left)
            nodes.append(node.val)
            dfs(node.right)
        dfs(root)
        ans = []
        for q in queries:
            # 把<=转化为>,bisect_right返回相等最右侧元素+1,大于该元素
            min_ = bisect_right(nodes, q)-1
            min = nodes[min_] if min_>=0 else -1
            # >=,bisect_left返回相等最左侧元素,大于该元素
            max_ = bisect_left(nodes, q)
            max = nodes[max_] if max_<len(nodes) else -1
            ans.append([min, max])
        return ans

6243. 到达首都的最少油耗

在这里插入图片描述

【无向、连通、无环】,实际上就是各个结点到0号的只有一条边。
而需要的车车数量就是【走过的边//seats】的向上取整。
对于某个边来说,有多少城市代表要走呢?答案是【子树的nodes数目】。
最终,该题转化为,从0开始使用dfs,对每个边而言其子树的nodes数目就是要走的个数。递归的返回给上一层的同时,更新ans即可。

class Solution:
    def minimumFuelCost(self, roads: List[List[int]], seats: int) -> int:
        ans = 0
        g = [[] for _ in range(len(roads) + 1)]
        # 双向边必须两个都加
        for x, y in roads:
            g[x].append(y)
            g[y].append(x)
        
        def dfs(x: int, fa: int) -> int:
            # size是子树规模,递归的返回给上一层
            size = 1
            for y in g[x]:
                # 避免陷入循环
                if y != fa:
                    size += dfs(y, x)
            # 0这个结点的子树规模不用算
            # 因为它并不从0出发到0
            if x:
                nonlocal ans
                # 向上取整的技巧
                ans += (size + seats - 1) // seats
            return size
        dfs(0, -1)
        return ans

6244. 完美分割的方案数

在这里插入图片描述

如何思考动态规划?

  1. 有哪些变量?
  2. 替换变量名,复述问题。
  3. 最后一步发生什么?通过思考最后一步来分解任务。
  4. 去掉最后一步,问题规模缩小。
  5. 得到状态转移方程。

本题变量,分割的个数i,字符串长度j。

把一个长为 j 的字符串,分割出i段的合法方案数。

最后一步是分割出 一个子串,长度为 x ,且这个字串是 s 的后缀。

去掉最后一步,子问题变成:
把一个长为 j-x 的字符串,分割出 i-1 段的合法方案数。

从第二部的问题描述中,【把一个长为 j 的字符串,分割出i段的合法方案数】可以写出 f[i][j]。真正的代码实现时,把分割个数写到外面一层比较方便,可以从小的分割个数转移到大的分割个数。
取不同的x,可以得到不同的方案数,所以关系是求和。

f [ i ] [ j ] = ∑ f [ i − 1 ] [ j − x ] = ∑ f [ i − 1 ] [ j ′ ] f[i][j] = \sum f[i-1][j-x] = \sum f[i-1][j'] f[i][j]=f[i1][jx]=f[i1][j]

这里满足 j ′ j' j 是第 i i i 段的开始下标。

  • 满足长度, j − j ′ + 1 > = m i n L e n g t h j-j'+1 >= minLength jj+1>=minLength
  • 满足要求, s [ j ′ ] s[j'] s[j] 是质数而 s [ j ] s[j] s[j] 不是质数

寻找初始值:空串分割为0个字串是1个合法的方案,即 f [ 0 ] [ 0 ] = 1 f[0][0]=1 f[0][0]=1

class Solution:
    def beautifulPartitions(self, s: str, k: int, minLength: int) -> int:
        # 看到10^9+7,考虑【动态规划】
        MOD = 10 ** 9 + 7
        def is_prime(c: str) -> bool:
            return c in "2357"

        # 判断是否可以在 j-1 和 j 之间分割(开头和末尾也算)
        def can_partition(j: int) -> bool:
            return j == 0 or j == s_len or not is_prime(s[j - 1]) and is_prime(s[j])

        # 剪枝:长度超了,第一个字母不是质数或最后一个是质数
        s_len = len(s)
        if k * minLength > s_len or not is_prime(s[0]) or is_prime(s[-1]):  
            return 0

        # 从字符串长度0,分割0段开始
        f = [[0] * (s_len + 1) for _ in range(k + 1)]
        f[0][0] = 1
        for i in range(1, k + 1):
            sum = 0
            # 枚举的起点前面一定有 i * minLength 的长度
            # 枚举的终点后面一定有 (k-i) * minLength 的长度
            for j in range(i*minLength, s_len - (k-i)*minLength + 1):
                # j'=j-minLength 双指针,枚举j的同时枚举了j'
                if can_partition(j - minLength): 
                    sum = (sum + f[i - 1][j - minLength]) % MOD  
                if can_partition(j): 
                    f[i][j] = sum
        return f[k][s_len]
        

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/21216.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

实现微服务:匹配系统(中)

目录 1、同步两个玩家的位置思路解析 2、实现了三个棋盘的同步原理 3、初始化一下我们的playerAplayerB 4、什么是线程为什么要用多线程&#xff1f; 5、如何去实现等待两名玩家输入 6、前端向后端发消息 7、在数据库中创建表record 1、同步两个玩家的位置思路解析 除了地…

koa框架(一) 认识koa

koa ​koa是express原班人马打造的轻量、健壮、富有表现力的nodejs框架。目前koa有koa1和koa2两个版本&#xff1b;koa2依赖Node.js 7.6.0或者更高版本&#xff1b;koa不在内核方法中绑定任何中间件&#xff0c;它仅仅是一个轻量级的函数库&#xff0c;几乎所有功能都必须通过…

[附源码]java毕业设计网上点餐系统

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

干货分享丨第五届“大数据安全与隐私计算”学术会议

开放隐私计算 开放隐私计算 开放隐私计算OpenMPC是国内第一个且影响力最大的隐私计算开放社区。社区秉承开放共享的精神&#xff0c;专注于隐私计算行业的研究与布道。社区致力于隐私计算技术的传播&#xff0c;愿成为中国 “隐私计算最后一公里的服务区”。 177篇原创内容 …

网页设计大作业模板-网页设计大作业(文房四宝 5页)-实训素材

⛵ 源码获取 文末联系 ✈ Web前端开发技术 描述 网页设计题材&#xff0c;DIVCSS 布局制作,HTMLCSS网页设计期末课程大作业 | 茶文化网站 | 中华传统文化题材 | 京剧文化水墨风书画 | 中国民间年画文化艺术网站 | 等网站的设计与制作| HTML期末大学生网页设计作业&#xff0c;W…

通过STM32F103C8T6配置完成基于SPI协议的0.96OLED屏显

文章目录前言一、SPI协议1、应用2、组成二、OLED屏显和汉字点阵编码原理1、汉字点阵编码原理2、OLED屏显三、OLED模块四、显示自己的学号和姓名五、显示温湿度&滑动显示长字符六、总结七、参考资料前言 硬件&#xff1a;stm32f103c8t6 核心板软件&#xff1a;keil5 mdk软件…

混沌引力搜索算法(CGSA)解决三个机械工程设计问题(Matlab代码实现)

&#x1f468;‍&#x1f393;个人主页&#xff1a;研学社的博客 &#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜…

_linux 进程间通信(匿名管道)

文章目录1. 匿名管道2. 利用通过匿名管道实现进程间通信2.1 实现思路2.2 父子进程实现通信的简单代码2.3 结果展示如下3. 总结管道特点4. 扩展&#xff08;好玩的--简单内存池&#xff09;思路&#xff1a;代码&#xff1a;1. 匿名管道 查看手册(man)&#xff1a; 翻译 #incl…

[附源码]计算机毕业设计JAVA基于JSP技术的新电商助农平台

[附源码]计算机毕业设计JAVA基于JSP技术的新电商助农平台 项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; …

Amine-PEG-Azide,NH2-PEG-N3,胺-PEG-叠氮PEG试剂供应

1、名称 英文&#xff1a;Amine-PEG-Azide&#xff0c;NH2-PEG-N3 中文&#xff1a;胺-聚二乙醇-叠氮 2、CAS编号&#xff1a;N/A 3、所属分类&#xff1a;DSPE PEG Azide PEG 4、分子量&#xff1a;可定制&#xff0c;NH2-PEG-N3 2000、胺-聚二乙醇-叠氮 10000、NH2-PEG-…

从零开始做一款Unity3D游戏<一>——亲自上手使用Unity

游戏设计入门 游戏设计文档 Hero Born游戏的单页文档 构建关卡 创建基本图形 在三维中思考 材质 白盒环境 光照基础 创建光源 Light组件的属性 在Unity中制作动画 创建动画片段 记录关键帧 曲线与切线 粒子系统 总结 本文主要来自<<C#实践入门>>哈…

【单片机】独立看门狗IWDG初始化

目录 看门狗简介&#xff1a; 初始化例子&#xff1a; 看门狗使能&#xff1a; 写保护&#xff1a; 看门狗重载&#xff1a; 看门狗复位时间计算&#xff1a;基本上看stm中文手册对照框图就很明确 看门狗简介&#xff1a; 此器件具有两个嵌入式看门狗外设&#xff0c;具有…

3-4数据链路层-局域网

文章目录一.基本概念1.网络拓扑2.传输介质3.介质访问控制方法4.局域网的分类5.逻辑链路控制&#xff08;LLC&#xff09;子层与媒体接入控制&#xff08;MAC&#xff09;子层二.以太网&#xff08;一&#xff09;以太网的传输介质与网卡1.传输介质2.网卡&#xff08;二&#xf…

[附源码]计算机毕业设计JAVA基于JSP学生信息管理系统

[附源码]计算机毕业设计JAVA基于JSP学生信息管理系统 项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM …

工具及方法 - 编辑二进制文件(使用VSCode和Notepad++的插件Hex Editor)

Visual Studio Code 在VSCode里安装插件&#xff0c;可以实现很多功能。 打开VSCode&#xff0c;在菜单里选择&#xff0c; View->Extensions&#xff0c;就会出现扩展插件的查找页面。 输入想要查找的插件名称&#xff0c;搜索&#xff0c;然后点击安装。 比如要用VSCode…

高性能零售IT系统的建设06-当应对大量HTTP请求时兼顾性能、处理速度的架构设计

前言 这个系列不像我的那些个“保姆式”教程&#xff0c;那些保姆式教程我一周最多可以写8篇&#xff0c;因为太简单了。充其量花的时间就是用“看漫画”的方式去组织我的截图和尽量少文字多Sample。 而高性能系统建设系列这一块不仅仅只有代码&#xff0c;相反它甚至不会多写…

力扣(LeetCode)25. K 个一组翻转链表(C++)

模拟 前置知识 : 反转链表、两两交换链表中的节点 。 LeetCode 有相应题目&#xff0c;可以先做。 设置哑结点 &#xff0c; 便于操作头结点。 翻转至少要 kkk 个结点 &#xff0c; 先检查剩余结点够不够 kkk 个。 不够 kkk 个就翻转完成了。 翻转分为组内翻转和首尾变向两步…

查找xml文件

一 前言 相比xml.dom.minidom&#xff0c;lxml.etree具有高效的查找方法&#xff0c;更方便&#xff0c;直接&#xff1b; 二、知识点&#xff1a;查找感兴趣的元素 举例一&#xff1a;递归遍历其下的所有子树&#xff08;包括子级&#xff0c;子级的子级&#xff0c;等等 …

nero platinum刻录光盘简要教程(文章末尾有教程链接)

nero platinum suit 介绍 使用nero express可以完成多数情况下的光盘应用。在nero platinum suit中单击nero express&#xff0c;这时可以看到nero express的工作界面&#xff0c;在这里面可以刻录数据光盘&#xff0c;可以刻录音乐光盘&#xff0c;可以刻录视频光盘&#xff…

SpringMVC集成静态资源

集成静态资源 静态资源&jsp是被谁处理的 tomcat是一个servlet容器&#xff0c;servlet容器中通常有servlet来处理各种请求&#xff0c;那么当访问静态资源或者jsp的时候&#xff0c;当然也是有servlet来处理这些请求的&#xff0c;但是并未在web.xml中配置哪个servlet来处…