LeetCode --- 156双周赛

news2025/5/18 13:19:01

题目列表

3541. 找到频率最高的元音和辅音
3542. 将所有元素变为 0 的最少操作次数
3543. K 条边路径的最大边权和
3544. 子树反转和

一、找到频率最高的元音和辅音

在这里插入图片描述
分别统计元音和辅音的出现次数最大值,然后相加即可,代码如下

// C++
class Solution {
    const string str = "aeiou";
public:
    int maxFreqSum(string s) {
        int cnt[26]{};
        int mx1 = 0, mx2 = 0;
        for(auto & e : s){
            cnt[e - 'a']++;
            if(str.find(e) == string::npos){
                mx1 = max(mx1, cnt[e - 'a']); // 更新辅音
            }else{
                mx2 = max(mx2, cnt[e - 'a']); // 更新辅音
            }
        }
        return mx1 + mx2;
    }
};
# Python
class Solution:
    def maxFreqSum(self, s: str) -> int:
        cnt = [0] * 26
        mx1 = 0
        mx2 = 0
        for e in s:
            x = ord(e) - ord('a')
            cnt[x] += 1
            if e in "aeiou":
                mx1 = max(mx1, cnt[x])
            else:
                mx2 = max(mx2, cnt[x])
        return mx1 + mx2

二、将所有元素变为 0 的最少操作次数

在这里插入图片描述
本题的难点在于一旦我们将区间内的最小值变为 0,那么剩余的不为 0 的数字就会被分成一段一段的区间,此时,我们需要在这些区间内再去进行操作,而这需要我们维护区间内的最小值,显然很困难,那有没有什么其他的思路?

  • 思路
    对于一个数字 x 来说,只有当它是区间内的最小值时,才可以通过操作被置为 0,而从贪心的角度来说,这个区间越大,则置为 0 的数越多,所进行的操作就会越少。所以我们只要计算对于同一个数字 x,它需要被分为多少个区间,才能让所有的 x 全部变为 0,而它分出的区间数就是它需要进行的最少操作次数。统计所有的数字对于答案的贡献即可

    • 这里暗含一个贪心的策略,优先将小的数字置为 0 会更优,因为小的数字置为 0,它依旧是小的数字,不会影响大的数字的分区个数,但是反过来,大的数字置为 0,就有可能将小的数字分成更多的区间,导致操作次数变多
    • 故这里我们计算出每个数字区间个数后直接相加,看似不论顺序,实质是从小的数字开始进行操作
    • 求解 x 为最小数字的区间,本质是求距离 x 最近的比它小的数字下标,可以用单调栈来求解
// C++
class Solution {
public:
    int minOperations(vector<int>& nums) {
        int n = nums.size();
        stack<int> st;
        vector<int> left(n, -1), right(n, n);
        // 计算区间
        for(int i = 0; i < n; i++){
            while(st.size() && nums[st.top()] > nums[i]){
                right[st.top()] = i;
                st.pop();
            }
            st.push(i);
        }
        st = stack<int>();
        for(int i = n - 1; i >= 0; i--){
            while(st.size() && nums[st.top()] > nums[i]){
                left[st.top()] = i;
                st.pop();
            }
            st.push(i);
        }
        unordered_map<int,set<pair<int,int>>> mp;
        for(int i = 0; i < n; i++){
            mp[nums[i]].emplace(left[i], right[i]);
        }
        int ans = 0;
        for(auto& [x, st] : mp){
            if(x){ // x = 0 不需要进行操作
                ans += st.size();
            }
        }
        return ans;
    }
};
  • 优化

    • 对于求区间个数的操作,我们可以在一次循环中得到,具体如下
// C++
class Solution {
public:
    int minOperations(vector<int>& nums) {
        int n = nums.size(), ans = 0;
        stack<int> st; // 单调递增 & 栈中无重复数字 & 不包含 0
        for(int i = 0; i < n; i++){
            while(st.size() && nums[st.top()] >= nums[i]){
             	// 这里只统计一定需要进行一次操作的数字个数,即左右边界已经明确的数字
             	// 和 nums[i] 相同的数字,由于右边界还不确定,此处不统计,等区间明确后在统计
                if(nums[st.top()] != nums[i]){
                    ans++;
                }
                st.pop();
            }
            if(nums[i]) // 0 不需要入栈
                st.push(i);
        }
        // 栈中剩余的数字,此时右边界已经确定,也需要进行一次操作才能被置为 0
        return ans + st.size();
    }
};
#Python
class Solution:
    def minOperations(self, nums: List[int]) -> int:
        ans = 0
        bottom, top = 0, 0 # 可以直接将 nums 当作栈进行使用,空间复杂度为 O(1)
        for i in range(len(nums)):
            while bottom != top and nums[top-1] >= nums[i]:
                if nums[top-1] != nums[i]:
                    ans += 1
                top -= 1
            if nums[i] > 0:
                nums[top] = nums[i]
                top += 1
        return ans + top - bottom

三、K 条边路径的最大边权和

在这里插入图片描述
本题先建图,然后直接用 dfs 进行遍历即可,注意,为了防止重复遍历某个状态,需要记忆化已经遍历过的状态,代码如下

// C++
class Solution {
public:
    int maxWeight(int n, vector<vector<int>>& edges, int k, int t) {
        vector<vector<pair<int,int>>> g(n);
        for(auto& e : edges){
            g[e[0]].emplace_back(e[1], e[2]);
        }
        
        int ans = -1;
        set<tuple<int,int,int>> st; // 记忆化遍历过的状态
        auto dfs = [&](this auto&& dfs, int x, int d, int s)->void{
            if(d == k){
                ans = max(ans, s);
                return;
            }
            if(st.count({x, d, s}))
                return;
            st.emplace(x, d, s);
            for(auto& [y, w] : g[x]){
                if(s + w < t){
                    dfs(y, d + 1, w + s);
                }
            }
        };
        for(int i = 0; i < n; i++){
            dfs(i, 0, 0);
        }
        return ans;
    }
};
# Python
class Solution:
    def maxWeight(self, n: int, edges: List[List[int]], k: int, t: int) -> int:
        g = [[] for _ in range(n)]
        for x, y, w in edges:
            g[x].append((y, w))
        
        ans = -1
        @cache
        def dfs(x:int, d:int, s:int):
            if d == k:
                nonlocal ans
                ans = max(ans, s)
                return
            for y, w in g[x]:
                if w + s < t:
                    dfs(y, d + 1, w + s)
        for i in range(n):
            dfs(i, 0, 0)
        return ans

四、子树反转和

在这里插入图片描述

本题的反转操作有距离限制,也就是说对当前结点进行反转操作之后,与它距离小于 k 的结点就不能进行反转操作了,所以我们在 dfs 遍结点的时候,需要增加两个参数 mul : 表示当前的结点取正还是取负cd : 多少距离后,就能再次进行反转操作,故我们有 dfs(x,fa,mul,cd)

  • x 结点不反转时, d f s ( x , f a , m u l , c d ) = s u m ( d f s ( y , x , m u l , ( c d   ?   c d − 1 , 0 ) ) ) + ( m u l   ?   n u m s [ x ]   :   − n u m s [ x ] ) dfs(x,fa,mul,cd)=sum(dfs(y,x,mul,(cd\ ?\ cd-1,0)))+(mul\ ?\ nums[x]\ : \ -nums[x]) dfs(x,fa,mul,cd)=sum(dfs(y,x,mul,(cd ? cd1,0)))+(mul ? nums[x] : nums[x]),其中 y 是结点 x 的所有子节点
  • x 结点反转且 cd == 0 时, d f s ( x , f a , m u l , c d ) = s u m ( d f s ( y , x , ! m u l , k − 1 ) ) + ( m u l   ?   − n u m s [ x ]   :   n u m s [ x ] ) dfs(x,fa,mul,cd)=sum(dfs(y,x,!mul,k-1))+(mul\ ?\ -nums[x]\ : \ nums[x]) dfs(x,fa,mul,cd)=sum(dfs(y,x,!mul,k1))+(mul ? nums[x] : nums[x]),其中 y 是结点 x 的所有子节点

代码如下

// C++
class Solution {
public:
    long long subtreeInversionSum(vector<vector<int>>& edges, vector<int>& nums, int k) {
        int n = nums.size();
        vector<vector<int>> g(n);
        for(auto & e : edges){
            g[e[0]].push_back(e[1]);
            g[e[1]].push_back(e[0]);
        }
        vector memo(n, vector(2, vector<long long>(k, -1)));
        auto dfs = [&](this auto&& dfs, int x, int fa, bool mul, int cd)->long long{ // f0, cd0, f1
            if(memo[x][mul][cd] != -1) return memo[x][mul][cd];
            long long res = mul ? nums[x] : -nums[x];
            for(int y : g[x]){
                if(y != fa){
                    res += dfs(y, x, mul, (cd ? cd - 1 : 0));
                }
            }
            if(cd == 0){
                long long res2 = mul ? -nums[x] : nums[x];
                for(int y : g[x]){
                    if(y != fa){
                        res2 += dfs(y, x, !mul, k - 1);
                    }
                }
                res = max(res, res2);
            }
            return memo[x][mul][cd] = res;
        };
        return dfs(0, -1, true, 0);
    }
};
# Python
class Solution:
    def subtreeInversionSum(self, edges: List[List[int]], nums: List[int], k: int) -> int:
        n = len(nums)
        g = [[] for _ in range(n)]
        for x,y in edges:
            g[x].append(y)
            g[y].append(x)
        
        memo = {}
        def dfs(x:int, fa:int, mul:bool, cd:int)->int:
            t = (x, mul, cd)
            if t in memo:
                return memo[t]
            res = nums[x] if mul else -nums[x]
            for y in g[x]:
                if y != fa:
                    res += dfs(y, x, mul, cd - 1 if cd > 0 else 0)
            
            if cd == 0:
                res2 = -nums[x] if mul else nums[x]
                for y in g[x]:
                    if y != fa:
                        res2 += dfs(y, x, not mul, k - 1)
                res = max(res, res2)
            memo[t] = res
            return res
        
        return dfs(0, -1, True, 0)

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

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

相关文章

npm 报错 gyp verb `which` failed Error: not found: python2 解决方案

一、背景 npm 安装依赖报如下错&#xff1a; gyp verb check python checking for Python executable "python2" in the PATH gyp verb which failed Error: not found: python2 一眼看过去都觉得是Python环境问题&#xff0c;其实并不是你python环境问题&#xf…

初识Linux · IP协议· 下

目录 前言&#xff1a; 内网IP和公网IP 内网IP 公网IP 路由 前言&#xff1a; 前文我们介绍了IP协议的协议头&#xff0c;通过源码等方式我们理解了IP协议中的字段&#xff0c;比如8位协议&#xff0c;比如通过环回问题引出的8位最大生存时间&#xff0c;比如8位协议&…

JAVA的常见API文档(上)

游戏打包 注意API文档中的方法不需要记忆&#xff01;&#xff01; 了解之后如果需要可以查询API文档 对Math的方法总结&#xff1a; 运用刚学的Math方法加快代码的运行效率 可以减少循环次数 找规律&#xff1a; 发现因子有规律&#xff1a; 必定一个大于平方根&#xff0c;…

Spark,连接MySQL数据库,添加数据,读取数据

连接数据库 可以看到shell中我们读取出的数据 在IDEA中打代码如果能输出跟shell中一样的结果即证明连接成功 【出错反思】 像我前面出错的原因就是在打代码时将密码输入错误 添加数据 读取数据就是在上面代码中一起展示了&#xff0c;这里我就不单独说了

【EDA软件】【联合Modelsim仿真使用方法】

背景 业界EDA工具仿真功能是必备的&#xff0c;例如Vivado自带仿真工具&#xff0c;且无需联合外部仿真工具&#xff0c;例如MoodelSim。 FUXI工具仿真功能需要联合Modelsim&#xff0c;才能实现仿真功能。 方法一&#xff1a;FUXI联合ModelSim 1 添加testbench文件 新建to…

【离散化 线段树】P3740 [HAOI2014] 贴海报|普及+

本文涉及知识点 C线段树 [HAOI2014] 贴海报 题目描述 Bytetown 城市要进行市长竞选&#xff0c;所有的选民可以畅所欲言地对竞选市长的候选人发表言论。为了统一管理&#xff0c;城市委员会为选民准备了一个张贴海报的 electoral 墙。 张贴规则如下&#xff1a; electoral…

CSP 2024 提高级第一轮(CSP-S 2024)单选题解析

单选题解析 第 1 题 在 Linux 系统中&#xff0c;如果你想显示当前工作目录的路径&#xff0c;应该使用哪个命令&#xff1f;&#xff08;A&#xff09; A. pwd B. cd C. ls D. echo 解析&#xff1a;Linux 系统中&#xff0c;pwd命令可以显示当前工作目录的路径。pwd&#x…

六、绘制图片

文章目录 1.创建一个红色图片2.加载bmp图片3.加载png、jpg图片 前面的几个示例&#xff0c;我们已经展示过如果在Linux系统下使用xlib接口向窗口中绘制文本、线、矩形&#xff1b;并设置文本、线条的颜色。并利用xlib提供的接口结合事件处理机制完成了一个自绘按钮控件功能。有…

Java 面向对象详解和JVM底层内存分析

先关注、点赞再看、人生灿烂&#xff01;&#xff01;&#xff01;&#xff08;谢谢&#xff09; 神速熟悉面向对象 表格结构和类结构 我们在现实生活中&#xff0c;思考问题、发现问题、处理问题&#xff0c;往往都会用“表格”作为工具。实际上&#xff0c;“表格思维”就是…

深度学习---知识蒸馏(Knowledge Distillation, KD)

一、知识蒸馏的本质与起源 定义&#xff1a; 知识蒸馏是一种模型压缩与迁移技术&#xff0c;通过将复杂高性能的教师模型&#xff08;Teacher Model&#xff09;所学的“知识”迁移到轻量级的学生模型&#xff08;Student Model&#xff09;&#xff0c;使学生模型在参数量和计…

基于CNN卷积神经网络的带频偏QPSK调制信号检测识别算法matlab仿真

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 5.算法完整程序工程 1.算法运行效果图预览 (完整程序运行后无水印) 2.算法运行软件版本 matlab2024b 3.部分核心程序 &#xff08;完整版代码包含详细中文注释和操作步骤视频&#xff09…

【DAY21】 常见的降维算法

内容来自浙大疏锦行python打卡训练营 浙大疏锦行 目录 PCA主成分分析 t-sne降维 线性判别分析 (Linear Discriminant Analysis, LDA) 作业&#xff1a; 什么时候用到降维 降维的主要应用场景 知识点回顾&#xff1a; PCA主成分分析t-sne降维LDA线性判别 通常情况下&#xff0c;…

校园社区小程序源码解析

基于ThinkPHP、FastAdmin和UniApp开发的校园社区小程序源码&#xff0c;旨在为校园内的学生和教职员工提供一个便捷的在线交流和服务平台。 该小程序前端采用UniApp进行开发&#xff0c;具有良好的跨平台兼容性&#xff0c;可以轻松发布到iOS和Android平台。同时&#xff0c;后…

第6章:文件权限

一、文件权限概述 Linux为了保证系统中每个文件的安全&#xff0c;引入了文件权限机制。针对于系统中的每一个文件Linux都可以提供精确的权限控制。它可以做到不同的用户对同一个文件具有不同的操作权利。而通常这个权利包括以下3个&#xff1a; 读的权利&#xff08;Read&…

C语言| 指针变量的定义

C语言| 指针的优点-CSDN博客 * 表示“指向”&#xff0c;为了说明指针变量和它所指向的变量之间的联系。 int * i&#xff1b;//表示指针变量i里面存放的地址&#xff0c;所指向的存储单元里的【数据】。 【指针变量的定义】 C语言规定所有变量&#xff0c;在使用前必须先定…

IntelliJ IDEA给Controller、Service、Mapper不同文件设置不同的文件头注释模板、Velocity模板引擎

通过在 IntelliJ IDEA 中的 “Includes” 部分添加多个文件头模板&#xff0c;并在 “Files” 模板中利用这些包含来实现不同类型文件的注释。以下是为 Controller、Service、Mapper 文件设置不同文件头的完整示例&#xff1a; 1. 设置 Includes 文件头模板 File > Settin…

【论文阅读】BEVFormer

〇、Introduction BEVFormer是现在端到端无人驾驶中常使用的一个Backbone&#xff0c;用于将六个视角下的图像转换为鸟瞰图视角下的特征&#xff0c;转换出的BEV特征则会被用于后续模块的特征交互。然而在这个模型设计的初期&#xff0c;其最本质的意图是为了提取用于各种CV任…

IDEA编辑器设置的导出导入

背景 最近新换了电脑&#xff0c;因为之前是 Intel 芯片的 Mac&#xff0c;这次换了 arm 架构的 M 芯片的 Mac&#xff0c;旧 Mac 上的很多软件不兼容&#xff0c;所以就没有选择换机数据迁移&#xff0c;一点一点下载、配置了所有环境。 导出 IDEA 支持设置的导入导出&…

成功案例丨从草图到鞍座:用先进的发泡成型仿真技术变革鞍座制造

案例简介 在鞍座制造中&#xff0c;聚氨酯泡沫成型工艺是关键环节&#xff0c;传统依赖实验测试的方法耗时且成本高昂。为解决这一问题&#xff0c;意大利自行车鞍座制造商 Selle Royal与Altair合作&#xff0c;采用Altair Inspire PolyFoam软件进行发泡成型仿真。 该工具帮助团…

电机试验平台:创新科技推动电动机研究发展

电机试验平台是电机制造和研发过程中不可或缺的重要设备&#xff0c;其功能涵盖了电机性能测试、电机寿命测试、电机质量评估等多个方面。随着科技的不断发展和电机应用领域的日益扩大&#xff0c;对电机试验平台的要求也越来越高。本文将从现代化电机试验平台的设计与应用两个…