【力扣周赛】第 112 场双周赛

news2024/11/23 6:27:42

文章目录

  • 竞赛链接
  • Q1:7021. 判断通过操作能否让字符串相等 I
  • Q2:7005. 判断通过操作能否让字符串相等 II(贪心)
  • Q3:2841. 几乎唯一子数组的最大和
    • 竞赛时代码——滑动窗口
  • Q4:8050. 统计一个字符串的 k 子序列美丽值最大的数目(贪心+计数+组合数学)
  • 成绩记录

竞赛链接

https://leetcode.cn/contest/biweekly-contest-112/

Q1:7021. 判断通过操作能否让字符串相等 I

https://leetcode.cn/problems/check-if-strings-can-be-made-equal-with-operations-i/

在这里插入图片描述

提示:
s1.length == s2.length == 4
s1 和 s2 只包含小写英文字母。

class Solution {
    public boolean canBeEqual(String s1, String s2) {
        // 取出各个字符
        char a = s1.charAt(0), b = s1.charAt(1), c = s1.charAt(2), d = s1.charAt(3);
        char a2 = s2.charAt(0), b2 = s2.charAt(1), c2 = s2.charAt(2), d2 = s2.charAt(3);
        // 比较
        return (a == a2 || a == c2) && (a + c == a2 + c2) && (b == b2 || b == d2) && (b + d == b2 + d2);
    }
}

Q2:7005. 判断通过操作能否让字符串相等 II(贪心)

https://leetcode.cn/problems/check-if-strings-can-be-made-equal-with-operations-ii/description/

在这里插入图片描述

提示:
n == s1.length == s2.length
1 <= n <= 10^5
s1 和 s2 只包含小写英文字母。

只要两个字符串的奇偶位的各个字符的数量相等,就一定可以通过交换位置换成相同的字符串。

class Solution {
    public boolean checkStrings(String s1, String s2) {
        // 分别记录两个字符串的奇偶位字符数量
        int[] cnt1 = new int[26], cnt2 = new int[26], cnt3 = new int[26], cnt4 = new int[26];
        int n = s1.length();
        for (int i = 0; i < n; ++i) {
            if (i % 2 == 0) {
                cnt1[s1.charAt(i) - 'a']++;
                cnt3[s2.charAt(i) - 'a']++;
            } else {
                cnt2[s1.charAt(i) - 'a']++;
                cnt4[s2.charAt(i) - 'a']++;
            }
        }
        // 比较是否相等
        return Arrays.equals(cnt1, cnt3) && Arrays.equals(cnt2, cnt4);
    }
}

Q3:2841. 几乎唯一子数组的最大和

https://leetcode.cn/problems/maximum-sum-of-almost-unique-subarray/

在这里插入图片描述
提示:
1 <= nums.length <= 2 * 10^4
1 <= m <= k <= nums.length
1 <= nums[i] <= 10^9

竞赛时代码——滑动窗口

滑动窗口,维护窗口内的总和以及独特元素数量。

class Solution {
    public long maxSum(List<Integer> nums, int m, int k) {
        Map<Integer, Integer> cnt = new HashMap<>();
        int n = nums.size();
        long sum = 0, ans = 0;
        // 双指针+滑动窗口
        for (int i = 0, j = 0; i < n; ++i) {
            // 加入元素
            cnt.merge(nums.get(i), 1, Integer::sum);
            sum += nums.get(i);
            // 移除元素
            if (i - j >= k) {       
                cnt.merge(nums.get(j), -1, Integer::sum);
                sum -= nums.get(j);
                if (cnt.get(nums.get(j)) == 0) cnt.remove(nums.get(j));
                j++;
            }
            // 如果是几乎唯一子数组,就尝试更新答案
            if (i - j + 1 == k && cnt.size() >= m) ans = Math.max(ans, sum);
        }
        return ans;
    }
}

Q4:8050. 统计一个字符串的 k 子序列美丽值最大的数目(贪心+计数+组合数学)

https://leetcode.cn/problems/count-k-subsequences-of-a-string-with-maximum-beauty/
在这里插入图片描述

提示:
1 <= s.length <= 2 * 10^5
1 <= k <= s.length
s 只包含小写英文字母。

贪心地选取出现次数最多的字符。

如果若干个字符的出现次数一样,那么就把答案乘上对应的组合数。

比如从 0,1,1,1,2,3 中取 k 为 4,那么 3 和 2 是一定要被选择的,然后在 3 个 1 中任意选择 2 个 1 即可。答案为 3 * 2 * 1 * C(3,2) = 18。

class Solution {
    public int countKSubsequencesWithMaxBeauty(String s, int k) {
        if (k > 26) return 0;

        long[] cnt = new long[26];          // 记录各个字符的数量
        for (char ch: s.toCharArray()) {
            cnt[ch - 'a']++;
        }
        Arrays.sort(cnt);                   // 按字符数量排序
        long ans = 1, MOD = (long)1e9 + 7;
        long mn = cnt[26 - k];              // 可选择的出现次数最少的字符出现次数
        ans = mn;
        // 求组合数是几选几 
        int end = -1;
        for (int i = 26 - k + 1; i < 26; ++i) {
            if (cnt[i] != mn) {
                if (end == -1) end = i;
            }
            ans = (ans * cnt[i]) % MOD;
        }
        if (end == -1) end = 26;
        for (int i = 0; i < end; ++i) {
            if (cnt[i] == mn) {
                int x = end - i;
                long y = op(x, k - 26 + end);   // 求组合数
                ans = (ans * y) % MOD;
                break;
            }
        }
        return (int)ans;
    }
    
    // 求组合数C(x, y)
    public long op(int x, int y) {
        long ans = 1, m = 1;
        while (y != 0) {
            ans *= x;
            m *= y;
            x--;
            y--;
        }
        return ans / m;
    }
}

成绩记录

在这里插入图片描述

就,还好。
WA 次数有点多。

在这里插入图片描述

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

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

相关文章

小白学go基础05-变量声明形式

和Python、Ruby等动态脚本语言不同&#xff0c;Go语言沿袭了静态编译型语言的传统&#xff1a;使用变量之前需要先进行变量的声明。 变量声明形式使用决策流程图 这里大致列一下Go语言常见的变量声明形式&#xff1a; var a int32 var s string "hello" var i 13 …

C# void 关键字学习

C#中void关键字是System.Void的别名&#xff1b; 可以将 void 用作方法&#xff08;或本地函数&#xff09;的返回类型来指定该方法不返回值&#xff1b; 如果C&#xff03;方法中没有参数&#xff0c;则不能将void用作参数&#xff1b;这是与C语言不同的&#xff0c;C语言有…

附录2-将三国演义按章节存储为不同的txt(bs4)

地址 《三国演义》全集在线阅读_史书典籍_诗词名句网 目录 1 项目分析 2 代码 1 项目分析 我们可以在首页中找到所有的章节 每一个章节是一个a标签&#xff0c;a标签连接到该章节的内容 但这个网站他有bug&#xff0c;章节都是乱套的&#xff0c;我们无视这种错误&#…

Python通过Socket操作RFID设备-盘点功能

项目介绍&#xff1a;根据这么多年的IT经验&#xff0c;需求通过与用户沟通发现的&#xff0c;机会也是这样出来的。仓库的小伙子跟我倒苦水&#xff0c;动不动实物盘点&#xff0c;几千颗物料&#xff0c;都忙疯了&#xff0c;而且&#xff0c;新的物料一入库&#xff0c;作为…

基于Matlab分析的电力系统可视化研究

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

什么是专线网络?互联网专线为什么贵

宽带主要分为专线和家庭宽带。一般来说&#xff0c;企业服务器和云服务提供商通常使用专线宽带&#xff0c;普通家庭接入家庭宽带。 什么是专线网络&#xff1f; 专线是指依托国内骨干网络和宽带城市网络资源&#xff0c;为企业集团客户提供专线接入方式互联网城市互联网&…

WebDAV之π-Disk派盘 + 无忧日记

无忧日记,生活无忧无虑。 给用户专业的手机记录工具,用户可以很轻松地通过软件进行每天发生事情的记录,可以为用户提供优质的工具与帮助,用户还可以通过软件来将地理位置,天气都记录在日记上,用户也可以通过软件来进行图片的导入,创建长图日记, 心情报表:用户写日记…

企业架构LNMP学习笔记14

默认官方模块&#xff1a; Gzip压缩&#xff1a; 压缩文件&#xff0c;使文件变小了&#xff0c;传输更快了&#xff0c;目前大部分市场浏览器都支持Gzip。 传输的时候省流量。 目的是为了提高用户的加载速度。 #开启gzip压缩 gzip on; #http协议版本 gzip_http_version 1.0…

css之层叠上下文

之前调元素的显示优先级时&#xff0c;只会默默的调z-index以达到效果&#xff0c;但有时不生效&#xff0c;又不知道根因。刚好详细了解到层叠上下文&#xff0c;可以解释此类问题。 什么是层叠上下文&#xff1f; 在CSS2.1规范中&#xff0c;每个盒模型的位置是三维的&…

智能电网时代:数字孪生的崭露头角

随着科技的不断进步&#xff0c;数字孪生已经开始在电力行业崭露头角&#xff0c;为这个关键的行业带来了前所未有的机遇和潜力。本文就带大家了解一下数字孪生在哪些方面为电力行业做出改变&#xff0c;以及未来的创新应用。 首先&#xff0c;数字孪生可以提高电力系统运营效率…

Mysql事务及锁

一、MVCC原理 1.1 版本链 trx_id &#xff1a;每次一个事务对某条聚簇索引记录进行改动时&#xff0c;都会把该事务的 事务id 赋值给 trx_id 隐藏列。 roll_pointer &#xff1a;每次对某条聚簇索引记录进行改动时&#xff0c;都会把旧的版本写入到 undo日志 中&#xff0…

木棒切割问题

题目很简单&#xff0c;就是我们在写二分的时候&#xff0c;会遇到这样的情况&#xff1a; mid left (right-left)/2; if (nums k)return mid;if (nums>k)left mid;if (nums<k)right mid-1; 若我们debug会发现其可能会一致卡在left mid&#xff0c;例如&#xff08…

ceph Monitor原理和代码流程介绍

Monitor介绍 Monitor在Ceph集群中扮演管理者的角色&#xff0c;维护了整个集群的状态&#xff0c;集群的状态被抽象成几个Map对象&#xff0c;包括monmap、osdmap、mdsmap、authmap、logmap等&#xff0c;保证集群的相关组件在同一时刻能够达成一致&#xff0c;相当于领导层。…

语言深入理解指针(非常详细)(三)

目录 数组名的理解使用指针访问数组 一维数组传参的本质二级指针指针数组指针数组模拟二维数组 数组名的理解 在上⼀个章节我们在使用指针访问数组的内容时&#xff0c;有这样的代码&#xff1a; int arr[10] {1,2,3,4,5,6,7,8,9,10}; int *p &arr[0];这里我们使用 &am…

医者无疆 | AI赋能大医精诚,医疗制药的进阶与突破

在历史的长河中&#xff0c;医学一直是人类文明的重要组成部分。从古希腊的希波克拉底到现代医学研究&#xff0c;医学始终与时俱进&#xff0c;为人类的健康和福祉做出了巨大的贡献。在互联网、大数据、5G等信息技术的迭代下&#xff0c;人工智能&#xff08;AI&#xff09;的…

cpp20规范 vs2019 STL库 unordered_map源码分析(整理后上传)

&#xff08;1&#xff09; unordered_map 模板有如下的模板调用和包含关系。 绿箭头1 处的模板类&#xff0c;继承了绿箭头2 &#xff0c; 绿箭头2 又继承了红框模板。但红框模板有一个泛化版本和一个特化版本&#xff0c;选择哪一个呢&#xff1f; 经过源代码查找&#xff0…

腾讯张乐:“反内卷”潮流已至,研发效能是软件企业必由之路

目录 Why&#xff5c;“狂飙”踩下刹车&#xff0c;“湖水岩石效应”加速显现 What&#xff5c;效能 ≠ 效率&#xff0c;效能 效率 有效性 How&#xff5c;研发效能“黄金三角” e.g.&#xff5c;软件研发效能实践中的“坑”与“解” 1. 忽视重视工程师的声音 2. “迷…

【Spring】SpringBoot的10个参数验证技巧

这里写目录标题 前言1.使用验证注解2 使用自定义验证注解3 在服务器端验证4 提供有意义的错误信息5 将 i18n 用于错误消息messages.properties6 使用分组验证7 对复杂逻辑使用跨域验证8 对验证错误使用异常处理9 测试你的验证逻辑10 考虑客户端验证总结 前言 参数验证很重要&am…

跨空间域数据管理分布式共识算法:现状、挑战和展望

跨空间域数据管理分布式共识算法&#xff1a;现状、挑战和展望 李伟明1&#xff0c;李彤1,2, 张大方1&#xff0c;戴隆超1,2, 柴云鹏1,2 1 中国人民大学信息学院&#xff0c;北京 100872 2 数据工程与知识工程教育部重点实验室&#xff0c;北京 100872 摘要&#xff1a;随着数字…

生信学院|09月08日《SOLIDWORKS扣合特征应用》

课程主题&#xff1a;SOLIDWORKS扣合特征应用课程时间&#xff1a;2023年09月08日 14:00-14:30主讲人&#xff1a;陈冬冬 生信科技 售后服务工程师1、什么是扣合特征2、唇缘与凹槽3、装配体凸4、台通风孔5、弹簧扣与弹簧扣卡槽请安装腾讯会议客户端或APP&#xff0c;微信扫描海…