Leetcode 第 417 场周赛题解

Leetcode 第 417 场周赛题解

  • Leetcode 第 417 场周赛题解
    • 题目1:3304. 找出第 K 个字符 I
      • 思路
      • 代码
      • 复杂度分析
    • 题目2:3305. 元音辅音字符串计数 I
      • 思路
      • 代码
      • 复杂度分析
    • 题目3:3306. 元音辅音字符串计数 II
      • 思路
      • 代码
      • 复杂度分析
    • 题目4:3307. 找出第 K 个字符 II
      • 思路
      • 代码
      • 复杂度分析

Leetcode 第 417 场周赛题解

题目1:3304. 找出第 K 个字符 I

思路

模拟字符串的构造。在执行足够多的操作后, word 中 至少 存在 k 个字符,此时返回 word 中第 k 个字符的值。

代码

/** @lc app=leetcode.cn id=3304 lang=cpp** [3304] 找出第 K 个字符 I*/// @lc code=start
class Solution
{
public:char kthCharacter(int k){string s = "a";while (s.length() < k){int len = s.length();for (int i = 0; i < len; i++)s += s[i] + 1;}return s[k - 1];}
};
// @lc code=end

复杂度分析

时间复杂度:O(logk)。

空间复杂度:O(1)。

题目2:3305. 元音辅音字符串计数 I

思路

利用滑动窗口取区间为 [left, right] 的 word 的子字符串,判断其是否每个元音字母(‘a’、‘e’、‘i’、‘o’、‘u’)至少出现一次,并且恰好包含 k 个辅音字母。

代码

/** @lc app=leetcode.cn id=3305 lang=cpp** [3305] 元音辅音字符串计数 I*/// @lc code=start
class Solution
{
public:int countOfSubstrings(string word, int k){int n = word.length();unordered_set<char> vowels = {'a', 'e', 'i', 'o', 'u'};int count = 0;for (int left = 0; left + 5 + k <= n; left++){int notVowel = 0;unordered_set<char> foundVowels; // 存放当前找到的元音字母for (int right = left; right < n; right++){char c = word[right];if (vowels.count(c))foundVowels.insert(c);elsenotVowel++;if (foundVowels.size() == 5 && notVowel == k)count++;}}return count;}
};
// @lc code=end

复杂度分析

时间复杂度:O(n2),其中 n 是字符串 word 的长度。

空间复杂度:O(1)。

题目3:3306. 元音辅音字符串计数 II

思路

问题等价于如下两个问题:

  • 每个元音字母至少出现一次,并且至少包含 k 个辅音字母的子串个数。记作 fk
  • 每个元音字母至少出现一次,并且至少包含 k+1 个辅音字母的子串个数。记作 fk+1

二者相减,所表达的含义就是恰好包含 k 个辅音字母了,所以答案为 fk - fk+1

代码

/** @lc app=leetcode.cn id=3306 lang=cpp** [3306] 元音辅音字符串计数 II*/// @lc code=start
class Solution
{
private:const unordered_set<char> vowels = {'a', 'e', 'i', 'o', 'u'};public:long long countOfSubstrings(string word, int k){return f(word, k) - f(word, k + 1);}// 辅函数long long f(string &word, int k){long long ans = 0;// 这里用哈希表实现,替换成数组会更快unordered_map<char, int> cnt1; // 每种元音的个数int cnt2 = 0;                  // 辅音个数int left = 0;for (char &c : word){if (vowels.count(c))cnt1[c]++;elsecnt2++;while (cnt1.size() == 5 && cnt2 >= k){char out = word[left];if (vowels.count(out)){if (--cnt1[out] == 0)cnt1.erase(out);}elsecnt2--;left++;}ans += left;}return ans;}
};
// @lc code=end

复杂度分析

时间复杂度:O(n),其中 n 是字符串 word 的长度。

空间复杂度:O(1) 或者 O(∣Σ∣),其中 ∣Σ∣=21。

题目4:3307. 找出第 K 个字符 II

思路

倒序遍历 operations。当 k 在字符串的右半边,也就是 k>2i 时,把 inc 增加 operations[i]。

代码

/** @lc app=leetcode.cn id=3307 lang=cpp** [3307] 找出第 K 个字符 II*/// @lc code=start
class Solution
{
public:char kthCharacter(long long k, vector<int> &operations){int inc = 0;for (int i = __lg(k - 1); i >= 0; i--){if (k > (1LL << i)){// k 在右半边inc += operations[i];k -= (1LL << i);}}return 'a' + inc % 26;}
};
// @lc code=end

复杂度分析

时间复杂度:O(logk)。

空间复杂度:O(1)。

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

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

相关文章

如何解决 MySQL ERROR 1040 (08004): Too many connections ?

MySQL 是最流行的开源关系数据库管理系统之一&#xff0c;它也是开发人员中非常常用的数据库。即便它高度健壮和可伸缩性极强&#xff0c;像任何软件一样&#xff0c;它也可能出现错误。我们会经常遇到一个错误&#xff0c;特别是在高流量系统中&#xff0c;error 1040 (08004)…

51c视觉~CV~合集3

我自己的原文哦~ https://blog.51cto.com/whaosoft/11668984 一、 CV确定对象的方向 介绍如何使用OpenCV确定对象的方向(即旋转角度&#xff0c;以度为单位)。 先决条件 安装Python3.7或者更高版本。可以参考下文链接&#xff1a; https://automaticaddison.com/how-to-s…

阳台山足球营地的停车位探寻

阳台山足球营地的环境是真好哈。停车场名称&#xff1a;阳台山森林公园配套停车场。应该很多爬山的人车子也停在这里。而且我没想到的&#xff0c;阳台山的山泉水还有不少居民每天提着空桶去山上装。看来环境是真的很好哈 停车场有地面和地下停车场&#xff0c;停车位个数查不…

java 数据存储方式

1. 变量存储 这是最基本的数据存储方式&#xff0c;通过声明变量来存储数据。变量可以是基本数据类型&#xff08;如int、float、char等&#xff09;&#xff0c;也可以是引用数据类型&#xff08;如对象、数组等&#xff09;。变量存储的数据通常存储在内存中&#xff0c;随着…

【记录】Excel|Excel 打印成 PDF 页数太多怎么办

【记录】Excel&#xff5c;解决 Excel 打印成 PDF 页数过多的问题 文章目录 【记录】Excel&#xff5c;解决 Excel 打印成 PDF 页数过多的问题方法一&#xff1a;调整页边距WPS OfficeMicrosoft Excel 方法二&#xff1a;优化页面布局调整列宽和行高使用“页面布局”视图合并单…

python全栈开发是什么?

全栈指掌握多种技能&#xff0c;并能利用多种技能独立完成产品。通俗的说就是与这项技能有关的都会&#xff0c;都能独立完成。 python&#xff0c;因为目前很火&#xff0c;能开发的项目很多。例如&#xff1a;web前端后端&#xff0c;自动化运维&#xff0c;软件、小型游戏开…

八大排序--01冒泡排序

假设有一组数据 arr[]{2&#xff0c;0&#xff0c;3&#xff0c;4&#xff0c;5&#xff0c;7} 方法&#xff1a;开辟两个指针&#xff0c;指向如图&#xff0c;前后两两进行比较&#xff0c;大数据向后冒泡传递&#xff0c;小数据换到前面。 一次冒泡后&#xff0c;数组中最大…

【网络篇】计算机网络——应用层详述(笔记)

目录 一、应用层协议原理 1. 进入应用层 2. 网络应用程序体系结构 &#xff08;1&#xff09;客户-服务器体系结构&#xff08;client-server architecture&#xff09; &#xff08;2&#xff09; P2P 体系结构&#xff08;P2P architecture&#xff09; 3. 进程间通讯 …

【GC日志和OOM日志分析】JVM GC日志和OOM Dump文件分析

1 缘起 充电、充电、充电。 增加一些必备的知识&#xff0c;帮助后续使用。 2 配置JVM参数 为分析GC日志以及OOM相关信息&#xff0c;配置JVM参数&#xff0c;分为三个部分&#xff1a; &#xff08;1&#xff09;堆内存&#xff0c;包括年轻代、最大堆内存&#xff1b; &a…

PELT算法

PELT算法的范畴 PELT算法&#xff08;Pruned Exact Linear Time&#xff09;属于时间序列分析和变点检测&#xff08;Change Point Detection&#xff09;范畴的算法。 从更广泛的角度来看&#xff0c;PELT算法还可以归类为以下几类算法的子集&#xff1a; 1. 时间序列分析&…

初识Linux · 文件(1)

目录 前言&#xff1a; 回顾语言层面的文件 理解文件的预备知识 文件和磁盘 使用和认识系统调用函数 前言&#xff1a; 本文以及下篇文章&#xff0c;揭露的都是Linux中文件的奥秘&#xff0c;对于文件来说&#xff0c;初学Linux第一节课接触的就是文件&#xff0c;对于C…

COMP 9517 Computer Vision week3

目录 特征表示图像特征概念(image feature)图像特征应该具备的属性 图像特征种类颜色特征颜色直方图(Color Histogram)颜色矩(Colour moments) 纹理特征(texture features)Haralick特征局部二值模式(Local Binary Patterns, LBP)尺度不变特征变换SIFT(Scale-invariant feature …

Error while loading conda entry point: conda-libmamba-solver

问题 解决方法 conda install --solverclassic conda-forge::conda-libmamba-solver conda-forge::libmamba conda-forge::libmambapy conda-forge::libarchive

如何实现事件流操作

文章目录 1 概念介绍2 使用方法3 示例代码我们在上一章回中介绍了通道相关的内容,本章回中将介绍StreamProvider组件.闲话休提,让我们一起Talk Flutter吧。 1 概念介绍 在Flutter中Stream是经常使用的组件,对该组件的监听可void main() {///让状态栏和程序的appBar融为一体…

zotero WebDAV同步忘记密码

https://www.jianguoyun.com/#/safety 找到应用密码

thinkphp 学习记录

1、PHP配置 &#xff08;点开链接后&#xff0c;往下拉&#xff0c;找到PHP8.2.2版本&#xff0c;下载的是ZIP格式&#xff0c;解压即用&#xff09; PHP For Windows: Binaries and sources Releases &#xff08;这里是下载地址&#xff09; 我解压的地址是&#xff1a;D:\…

Gitlab flow工作流

Gitlab flow Gitlab flow 是 Git flow 与 Github flow 的综合。它吸取了两者的优点&#xff0c;既有适应不同开发环境的弹性&#xff0c;又有单一主分支的简单和便利。它是 Gitlab.com 推荐的做法。 1 上游优先 Gitlab flow 的最大原则叫做"上游优先"&#xff08;…

【408计算机考研课程】数据结构-数据结构在学什么?

前言 数据结构在学什么&#xff1f; 如何用程序代码把现实世界的问题信息化如何用计算机高效地处理这些信息从而创造价值 第一章&#xff1a;数据结构在学什么&#xff1f; 总览 什么是数据&#xff1f; 简介&#xff1a;数据是信息的载体&#xff0c;是描述客观事物属性的数、…

el-pagination组件封装

组件使用 源代码&#xff1a; <script setup> import Pagination from /components/pagination/index.vue import {ref} from "vue";const pageNum ref(1) const pageSize ref(10) const total ref(120)function loadData() {// 加载数据 } </script>…

拓扑排序简介

拓扑排序(Topological Sort)是一种重要的图算法,用于对有向无环图(DAG, Directed Acyclic Graph)中的节点进行排序。拓扑排序的结果是一种线性序列,使得对于图中的任意一条有向边(u, v),顶点u都在顶点v之前。这种排序常用于任务调度、编译器依赖关系分析等领域。 拓…