LeetCode 第417场周赛个人题解

news2024/9/29 15:47:58

目录

Q1. 找出第 K 个字符 I

原题链接

思路分析

AC代码

Q2. 元音辅音字符串计数 I

原题链接

思路分析

AC代码

Q3. 元音辅音字符串计数 II

原题链接

思路分析

AC代码

Q4. 找出第 K 个字符 II

原题链接

思路分析

AC代码


Q1. 找出第 K 个字符 I

原题链接

Q1. 找出第 K 个字符 I

思路分析

签到题就直接模拟吧

AC代码

class Solution:
    def kthCharacter(self, k: int) -> str:
        s = [0]
        for i in range(k):
            ns = list((c + 1) % 26 for c in s)
            s += ns
            if len(s) > k: break
        return str(chr(s[k - 1] + ord('a')))

Q2. 元音辅音字符串计数 I

原题链接

Q2. 元音辅音字符串计数 I

思路分析

见T3

AC代码

class Solution:
    def countOfSubstrings(self, s: str, k: int) -> int:
        n = len(s)
        st = set("aeiou")
        acc = [[0] * (n + 1) + [n]
        ,[0] * (n + 1) + [n]
        ,[0] * (n + 1) + [n]
        ,[0] * (n + 1) + [n]
        ,[0] * (n + 1) + [n]
        ]

        acc1 = [0] * (n + 1) + [n]
        for i, c in enumerate(s):
            acc[0][i + 1] = acc[0][i] + (1 if c == 'a' else 0)
            acc[1][i + 1] = acc[1][i] + (1 if c == 'e' else 0)
            acc[2][i + 1] = acc[2][i] + (1 if c == 'i' else 0)
            acc[3][i + 1] = acc[3][i] + (1 if c == 'o' else 0)
            acc[4][i + 1] = acc[4][i] + (1 if c == 'u' else 0)
            acc1[i + 1] = acc1[i] + (0 if c in st else 1)
        res = 0
        for i in range(n):
            l = bisect_left(acc1, k + acc1[i])
            r = bisect_right(acc1, k + acc1[i]) - 1
            if l > n:
                break
            
            b = max(bisect_right(acc[c], acc[c][i]) for c in range(5))

            if b > n:
                break
            l = max(i, b, l)
            if r >= l:
                res += r - l + 1
        return res

Q3. 元音辅音字符串计数 II

原题链接

Q3. 元音辅音字符串计数 II

思路分析

前缀和+二分

滑窗可以写,但是写红温了,还是写了沟槽的二分

开5个元音前缀和数组,一个辅音前缀和数组

枚举 i ,二分合法右端点,累计贡献

时间复杂度:O(nlogn)

AC代码

class Solution:
    def countOfSubstrings(self, s: str, k: int) -> int:
        n = len(s)
        st = set("aeiou")
        acc = [[0] * (n + 1) + [n]
        ,[0] * (n + 1) + [n]
        ,[0] * (n + 1) + [n]
        ,[0] * (n + 1) + [n]
        ,[0] * (n + 1) + [n]
        ]

        acc1 = [0] * (n + 1) + [n]
        for i, c in enumerate(s):
            acc[0][i + 1] = acc[0][i] + (1 if c == 'a' else 0)
            acc[1][i + 1] = acc[1][i] + (1 if c == 'e' else 0)
            acc[2][i + 1] = acc[2][i] + (1 if c == 'i' else 0)
            acc[3][i + 1] = acc[3][i] + (1 if c == 'o' else 0)
            acc[4][i + 1] = acc[4][i] + (1 if c == 'u' else 0)
            acc1[i + 1] = acc1[i] + (0 if c in st else 1)
        res = 0
        for i in range(n):
            l = bisect_left(acc1, k + acc1[i])
            r = bisect_right(acc1, k + acc1[i]) - 1
            if l > n:
                break
            
            b = max(bisect_right(acc[c], acc[c][i]) for c in range(5))

            if b > n:
                break
            l = max(i, b, l)
            if r >= l:
                res += r - l + 1
        return res

Q4. 找出第 K 个字符 II

原题链接

Q4. 找出第 K 个字符 II

思路分析

递归

如上图所示,最终的数组其实就是不断二倍得到的

我们可以建立简单的递推关系

给定k,我们可以算出k是第几次操作得到的(取log2即可)

那么根据操作类型可以推出和对称位置的颜色关系(+1还是相同)

直接递归即可

时间复杂度:O(log^2 k)

AC代码

import math

class Solution:
    def kthCharacter(self, k: int, operations: list[int]) -> str:
        def dfs(i: int) -> int:
            if i <= 0: return 0
            if i == 1:
                return 0
            b = math.ceil(math.log2(i)) - 1
            return (dfs(i - pow(2, b)) + (1 if operations[b] == 1 else 0)) % 26
            
        return chr(dfs(k) + ord('a'))

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

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

相关文章

ethtool网络命令

1、ethtool命令描述 ethtool 是用于查询及设置网卡参数的命令。 2、查看网卡eth0信息 [rootes01 ~]# ethtool eth0 3、查看网络eth0速率 [rootmgr2 tmp]# ethtool -S eth0 4、设置网口 设置网口速率10/100/1000M、设置网口半/全双工、设置网口是否自协商 ethtool –s eth…

现在企业生存都困难,还谈什么数字化转型?

在当下经济大环境不好的情景下&#xff0c;经常听到如下论调&#xff1a;企业生存都困难&#xff0c;还谈什么数字化?这一论调反映了在当前经济环境下&#xff0c;一些企业对于数字化转型的疑虑和担忧&#xff0c;同时对数字化转型也缺乏正确的认知。下面笔者就上述论调进行简…

JAVA TCP协议初体验

文章目录 一、需求概述二、设计选择三、代码结构四、代码放送五、本地调试1. 服务端日志2. 客户端日志3. 断线重连日志 六、服务器部署运行1. 源码下载2. 打包镜像3. 运行容器 一、需求概述 最近开发某数据采集系统&#xff0c;系统整体的数据流程图如下&#xff1a; #mermaid…

聚观早报 | 淘宝已接入微信支付;Meta Orion AR眼镜发布

聚观早报每日整理最值得关注的行业重点事件&#xff0c;帮助大家及时了解最新行业动态&#xff0c;每日读报&#xff0c;就读聚观365资讯简报。 整理丨Cutie 9月29日消息 淘宝已接入微信支付 Meta Orion AR眼镜发布 iQOO 13将登陆印度市场 小鹏汽车加码布局上海 哔哩哔哩…

电脑自带dll修复在哪里,dll丢失的6种解决方法总结

在现代科技日新月异的时代&#xff0c;电脑已经成为我们生活中不可或缺的一部分。然而&#xff0c;在使用电脑的过程中&#xff0c;我们常常会遇到一些常见的问题&#xff0c;其中之一就是dll文件丢失或损坏。当这些dll文件丢失或损坏时&#xff0c;可能会导致某些应用程序无法…

网络抓包03 - 实践篇

声明&#xff1a; 本文中提及的APK及相关内容仅用于学习和交流目的&#xff0c;不涉及任何商业用途。本文不鼓励或支持任何形式的版权侵犯行为&#xff0c;同时也强调对软件的安全使用。我们尊重和维护开发者的权益&#xff0c;强烈建议读者在使用软件时遵守相关法律法规&#…

烟雾检测算法、明烟明火检测、烟火识别算法

烟火检测是一种基于先进技术的安全监控手段&#xff0c;主要用于及时发现和预防火灾等安全事故。其技术原理和应用领域可以详细阐述如下&#xff1a; 技术原理 烟火检测算法主要依赖于计算机视觉、深度学习以及图像处理技术。具体步骤包括&#xff1a; 1、数据采集与预处理&…

jQuery——css

本文分享到此结束&#xff0c;欢迎大家评论区相互讨论学习&#xff0c;下一篇继续分享jQuery中offset 和 position的学习。

深度学习--------------------------------门控循环单元GRU

目录 门候选隐状态隐状态门控循环单元GRU从零开始实现代码初始化模型参数定义隐藏状态的初始化函数定义门控循环单元模型训练该部分总代码简洁代码实现 做RNN的时候处理不了太长的序列&#xff0c;这是因为把整个序列信息全部放在隐藏状态里面&#xff0c;当时间很长的话&#…

SpringCloud学习记录|day1

学习材料 2024最新SpringCloud微服务开发与实战&#xff0c;java黑马商城项目微服务实战开发&#xff08;涵盖MybatisPlus、Docker、MQ、ES、Redis高级等&#xff09; 学redis讲到微服务就停了&#xff0c;nginx也是。 所以嘛&#xff0c;我终于来到微服务了。 复习MyBatisP…

鸿蒙HarmonyOS开发生态

1、官网 华为开发者联盟-HarmonyOS开发者官网&#xff0c;共建鸿蒙生态 2、开发工具IDE下载及使用 https://developer.huawei.com/consumer/cn/ 3、使用帮助文档 4、发布到华为应用商店 文档中心

免费分享一套SpringBoot+Vue火车票订票管理系统【论文+源码+SQL脚本】,帅呆了~~

大家好&#xff0c;我是java1234_小锋老师&#xff0c;看到一个不错的SpringBootVue火车票订票管理系统&#xff0c;分享下哈。 项目视频演示 【免费】SpringbootVue火车票订票管理系统 Java毕业设计_哔哩哔哩_bilibili 项目介绍 传统办法管理信息首先需要花费的时间比较多&…

CEX上币趋势分析:Infra赛道与Ton生态的未来

在当前的加密市场中&#xff0c;CEX&#xff08;中心化交易所&#xff09;上币的选择愈发重要&#xff0c;尤其是对项目方而言。根据 FMG 的整理&#xff0c;结合「杀破狼」的交易所上币信息&#xff0c;显然 Infra 赛道成为了交易所的热门选择&#xff0c;而 Ton 生态也展现出…

相互作用感知的 3D 分子生成 VAE 模型 - DeepICL 评测

DeepICL 是一个基于相互作用感知的 3D 分子生成模型&#xff0c;能够在目标结合口袋内进行相互作用引导的小分子设计。DeepICL 通过利用蛋白质-配体相互作用的普遍模式作为先验知识&#xff0c;在有限的实验数据下也能实现高度的泛化能力。 一、背景介绍 DeepICL 来源于韩国科学…

CHItrans简介--DVM

DVM基础flow 注&#xff1a;上图中&#xff0c;没有画出DVM指令对应的snoop request&#xff0c;相关snp请求如下所示&#xff1a; 对应的snp请求 Non-sync DVM trans flow Sync DVM trans flow Flow Control 后续的说明&#xff0c;参考&#xff1a; CHI协议之DVM操作_dvm r…

MySql语言操作数据库---MySql引擎,数据表,约束,基本查询,条件查询

数据库引擎 作用:引擎决定了数据是如何存在于数据库中的.不同引擎存储结构和特征是不同的. 常见引擎: InnoDB,MyISAM,MemoryMysql引擎操作: 查看支持的引擎: show engines; 给表设置引擎:create table student2(name varchar(20),age int )engine InnoDB; -- todo 展示所有的…

elasticsearch_exporter启动报错 failed to fetch and decode node stats

最近把服务器迁移到了ubuntu系统&#xff0c;结果发现在centos还正常运行的elasticsearch_exporter&#xff0c;用systemd启动后一直报错 failed to fetch and decode node stats 在网上翻了大半年&#xff0c;竟然都无解&#xff01;这种报错&#xff0c;很明显就是你的ES密码…

使用WPF实现一个快速切换JDK版本的客户端工具

发现网上一键切换JDK环境的方法都是在mac或Linux下的&#xff0c;本人主力电脑是Windows&#xff0c;于是看了一下WPF的文档&#xff0c;自己开发了一个客户端。 直接上代码吧&#xff1a; using JavaSwitch.Properties; using Newtonsoft.Json; using System; using System.…

本地IO与远程IO:揭秘工业自动化中的两大关键角色

在工业自动化领域&#xff0c;IO&#xff08;Input/Output&#xff0c;输入/输出&#xff09;模块扮演着至关重要的角色。它们作为连接控制系统与现场设备的桥梁&#xff0c;负责数据的采集与指令的执行。然而&#xff0c;随着技术的不断进步&#xff0c;IO模块也分为本地IO和远…

【百度文心智能体】想开发爆款智能体?来看看黑神话旅游指南 智能体开发流程大揭秘

&#x1f3ac; 博主&#xff1a;鸽芷咕 ⛺️生活的理想&#xff0c;就是为了理想的生活! 前言 2022年到2023年整年度随着 ChatGPT的爆火&#xff0c;“AI 人工智能 智能助手”概念开始引起各行各业的广泛关注&#xff0c;一些曾经存在于科幻片中的智能助手&#xff0c;到如今也…