LeetCode---389周赛

题目列表

3083. 字符串及其反转中是否存在同一子字符串

3084. 统计以给定字符开头和结尾的子字符串总数

3085. 成为 K 特殊字符串需要删除的最少字符数

3086. 拾起 K 个 1 需要的最少行动次数

一、字符串及其反转中是否存在同一子字符串

 直接暴力枚举即可,代码如下

class Solution {
public:bool isSubstringPresent(string s) {bool vis[26][26]={0};// vis[x][y] 表示(s[i-1],s[i])是否出现过for(int i=1;i<s.size();i++){int x = s[i-1]-'a',y = s[i]-'a';vis[x][y]=true;if(vis[y][x])return true;}return false;}
};// 用位运算优化
class Solution {
public:bool isSubstringPresent(string s) {int vis[26]={0};for(int i=1;i<s.size();i++){int x = s[i-1]-'a',y = s[i]-'a';vis[x]|=(1<<y);if(vis[y]>>x & 1)return true;}return false;}
};

二、统计以给定字符开头和结尾的子字符串的总数

这题就是纯数学题,就是要求我们找出特定字符的个数,然后从中选出两个组成子字符串,这题单一字符也符合条件,所以答案为n*(n-1)/2+n,n表示字符串中特定字符的出现次数

代码如下

class Solution {
public:long long countSubstrings(string s, char c) {long long n = count(s.begin(),s.end(),c);return n*(n-1)/2+n;}
};

三、成为K特殊字符串需要删除的最少字符数

仔细读完题目,你会发现这题其实和字符没多大关系,关键是频率,思路如下:

首先我们用freq[26]统计各个字符出现的次数(即频率),然后对freq进行排序,一共就26个字母的频率,我们可以暴力枚举以freq[i]为左端点,freq[i]+k为右端点的频率区间,在该区间内的字符不需要被修改,出现次数在该区间左边的字符要全被删除,出现次数在该区间右边的字符要被减少到freq[i]+k,枚举26次就能得到答案。

如何快速找到freq[i]+k对应的freq数组下标?用二分

如何快速得到前i个字符的出现次数?用前缀和

当然这题的freq数组不是很大,也就26个数,我们也可以直接遍历数组,不用二分+前缀和

代码如下

class Solution {
public:int minimumDeletions(string word, int k) {//统计频率int freq[26]={0};for(const auto&e:word)freq[e-'a']++;sort(freq,freq+26);int pre[27]={0};for(int i=0;i<26;i++) pre[i+1]=pre[i]+freq[i];int ans = INT_MAX;for(int i=0;i<26;i++){if(freq[i]==0) continue;int target=freq[i]+k;int l=i,r=25;while(l<=r){int m=l+(r-l)/2;if(freq[m]>target) r=m-1;else l=m+1;}ans=min(ans,pre[i]+pre[26]-pre[l]-target*(26-l));}return ans;}
};class Solution {
public:int minimumDeletions(string word, int k) {int freq[26]={0};for(const auto&e:word)freq[e-'a']++;sort(freq,freq+26);int ans = 0;for(int i=0;i<26;i++){if(freq[i]==0) continue;int res = 0;for(int j=i;j<26;j++)res += min(freq[j],freq[i]+k);ans=max(ans,res);// 求能保持不变的最大字符数量}return word.size()-ans;}
};

四、拾起K个1需要的最少的行动次数

设 i 为Alice的站立位置的下标,j 为 1 所在位置下标

根据贪心,我们可以归纳出以下几个步骤(按照优先级排序):

a、拿 i 左右两边的1(如果 i 左右是1的话)--- 只需行动 | i - j | = 1次

b、执行操作1将maxChanges个1放在 i 的左边/右边,再执行操作2,拿到1 --- 只需行动2次

c、执行操作2将被 i 附近的1拿到 --- 需要行动 | i - j | >= 2

(如果 i 本身就是1,那么不需要操作就直接拿到一个1,该行动在代码中与步骤a和并了,可以暂不考虑)

如果需要拿出的K个1可以在前两个步骤之内完成,可以直接计算出答案(具体看代码)

否则,我们在前两步得到的x个1的基础上,再得到 K - x 个1即可,很多人都会有这样的思维惯性,但是这样是不正确的,因为步骤a和步骤c是密切相关的,我们在得到x个1时,就已经确定了Alice的位置,但是这个位置不一定是最优的,因为它还会影响步骤c,所以我们应该把步骤a和步骤c放在一起考虑,步骤b的操作次数单独计算。

如何计算步骤a和步骤c得到的 K - maxChanges 个1需要的最少操作次数?

其实观察它们的表达是| i - j | 我们就能知道,我们要求的是  K - maxChanges 个1 到达某个位置的最短的距离和,用中位数贪心【中位数贪心的证明如下】

代码如下

class Solution {
public:long long minimumMoves(vector<int>& nums, int k, int maxChanges) {int n = nums.size();vector<int>pos;// 求连续1的个数int mx = 0;for(int i = 0; i < n; i++){if(nums[i]==0) continue;pos.push_back(i);//记录1出现的位置int j=i++;while(i<n&&nums[i]){pos.push_back(i);//记录1出现的位置i++;}mx=max(mx,i-j);}mx = min(3,min(k,mx));if(mx+maxChanges>=k)return max(mx-1,0)+(k-mx)*2LL;// 只用步骤a/步骤a+步骤b的操作次数int size = k - maxChanges; // 步骤a+步骤c需要的1的个数int m = pos.size();long long pre[m+1]; pre[0] = 0;for(int i = 0; i < m; i++) pre[i+1] = pre[i] + pos[i];long long ans = LLONG_MAX;for(int i = 0; i + size-1 < m; i++){int l = i, r = i + size - 1;int m = l + (r-l)/2;// pos[m]是中位数long long left = 1LL*(m-l)*pos[m]-(pre[m]-pre[l]);long long right = pre[r+1]-pre[m+1]-1LL*(r-m)*pos[m];ans = min(ans, left+right);}return ans+2LL*maxChanges;}
};

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

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

相关文章

【PHP + 代码审计】数组函数

&#x1f36c; 博主介绍&#x1f468;‍&#x1f393; 博主介绍&#xff1a;大家好&#xff0c;我是 hacker-routing &#xff0c;很高兴认识大家~ ✨主攻领域&#xff1a;【渗透领域】【应急响应】 【Java、PHP】 【VulnHub靶场复现】【面试分析】 &#x1f389;点赞➕评论➕收…

Redis 教程系列之Redis 数据备份与恢复(五)

Redis SAVE 命令用于创建当前数据库的备份。 语法 redis Save 命令基本语法如下&#xff1a; redis 127.0.0.1:6379> SAVE 实例 redis 127.0.0.1:6379> SAVE OK 该命令将在 redis 安装目录中创建dump.rdb文件。 恢复数据 如果需要恢复数据&#xff0c;只需将备份…

力扣面试150 x 的平方根 二分 换底法 牛顿迭代法 一题多解

Problem: 69. x 的平方根 思路 &#x1f468;‍&#x1f3eb; 参考题解 &#x1f496; 袖珍计算器算法 class Solution {public int mySqrt(int x){if (x 0)return 0; // Math.exp(3)&#xff1a;e的三次方int ans (int) Math.exp(0.5 * Math.log(x));return (long) (an…

【数据库】MySQL库与表的基本操作

目录 一、数据库概述 1. SQL分类 2. 存储引擎 二、库的操作 1. 创建数据库 2. 字符集与校验规则 3. 查看数据库 4. 修改数据库 5. 删除数据库 6. 查看连接情况 三、表的操作 1. 创建数据表 2. 查看数据表 3. 修改数据表 4. 删除数据表 一、数据库概述 1. SQL分…

PhpSpreadsheet 读取 excel 里面的图片

使用 phpSpreadSheet 插件去读取 excel 里面的图片时发现坑点很多&#xff0c;这里做一个总结 我使用的是 tp 框架 一、安装 phpSpreadSheet 插件 在composer.json配置 "require": {..."phpoffice/phpspreadsheet": "*" } composer安装 co…

配置环境安装包遇到的问题

1. error: could not install packages due to an oserror: [errno 28] no space left on device 说是磁盘占用过多&#xff0c;查看磁盘占用情况。 df -h 果然占比100% 清理了众多缓存.cache都不行&#xff0c;而且其他利用率很低&#xff0c;可能是pip install的过程中使…

代码随想录刷题随记4-链表

代码随想录刷题随记4 文章目录 代码随想录刷题随记424. 两两交换链表中的节点19.删除链表的倒数第N个节点面试题 02.07. 链表相交142.环形链表II 24. 两两交换链表中的节点 leetcode 链接 没什么技巧&#xff0c;主要考察链表操作的熟练程度 class Solution { public:ListNod…

qt 实现 轮播图效果,且还有 手动 上一页和下一页 已解决

QT中有 轮播图的需求&#xff0c;按照正常html版本 。只需要配置数组就能搞定&#xff0c;但是c qt版本 应该用什么了。 第一想到的是采用定时器。 // 定时器初始化{m_pTime new QTimer(this);m_pTime->start(4 * 1000);//启动定时器并设置播放时间间隔m_pAutoFlag true;/…

TikCloud天玑云微服务技术选型

单体多机负载均衡详见:PUSDN 技术选型 平台采用Java开发语言,具有可移植性、跨平台等特性。同时,平台提供跨平台技术解决方案、Windows、MacOS、Linux多端互通,pgz-serial串口、建行POS收银等,都是基于本平台衍生的跨平台案例。 功能介绍使用技术优势/特性开发语言Java主…

数据库查询所有表和字段

查询所有表和字段 介绍 有时候可能要展示所有的表以及所有的字段&#xff0c;下面介绍oracle和mysql的方法以及代码 oracle sql 查询所有表 select Table_NAME from all_tables where owner 表空间 查询字段 SELECT * FROM user_tab_columns where table_name upper(表名…

【python】python turtle绘制坤坤打球

一、效果图&#xff1a; 二、准备工作 &#xff08;1)、导入必要的模块&#xff1a; 代码首先导入了需要使用的模块&#xff1a;requests、lxml和csv。 import requests from lxml import etree import csv 如果出现模块报错 进入控制台输入&#xff1a;建议使用国内镜像源 p…

智慧公厕:跨界融合,打造智慧城市新名片

随着城市化进程的不断加快&#xff0c;公共厕所建设成为一个亟待解决的问题。传统的公厕存在着管理繁琐、卫生差、服务不到位等一系列问题&#xff0c;与城市发展的节奏不协调。为此&#xff0c;推进新型智慧公厕建设成为了一个重要的解决方案。智慧公厕的建设需要推进技术融合…

Day32 贪心算法 part02

Day32 贪心算法 part02 122.买卖股票的最佳时机 II 我的思路&#xff1a; 只有当后一天比前一天价格高时&#xff0c;才出售&#xff0c;profit才累加 解答&#xff1a; class Solution {public int maxProfit(int[] prices) {if(prices.length 0) {return 0;}int profit …

【论文精读】VIT:vision transformer论文

相关文章 【论文精读】Transformer&#xff1a;Attention Is All You Need 文章目录 相关文章一、文章概览&#xff08;一&#xff09;研究背景&#xff08;二&#xff09;核心思路&#xff08;三&#xff09;相关工作&#xff08;三&#xff09;文章结论 二、模型细节&#x…

数据库中什么时候使用自增id,什么时候不能使用

在数据库中&#xff0c;自增ID的使用场景主要有以下几个&#xff1a; 插入记录时不需要指定ID&#xff1a;使用自增ID可以避免手动指定ID&#xff0c;从而避免了因重复ID导致的错误数据库自动编号&#xff0c;速度快&#xff1a;数据库会按照预设的步长&#xff08;默认为1&am…

【MySQL系列】优化数据库时区设置,确保数据一致性与准确性

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…

Neo4J导入OWL文件

1.neosemantics版本分为4.0以下和4.0以上&#xff0c;两者区别大&#xff0c;我使用的是4.0以上版本&#xff0c;所以参考的是以下文章 owl导入Neo4j-CSDN博客 Neo4j图数据库简介、安装、使用、导入RDF文件_rdf导入neo4j-CSDN博客 2.不同版本的有些函数是不能通用的。 比如…

图论基础|深度优先dfs、广度优先bfs

dfs 与 bfs 区别 提到深度优先搜索&#xff08;dfs&#xff09;&#xff0c;就不得不说和广度优先搜索&#xff08;bfs&#xff09;有什么区别 先来了解dfs的过程&#xff0c;很多录友可能对dfs&#xff08;深度优先搜索&#xff09;&#xff0c;bfs&#xff08;广度优先搜索…

鸿蒙Harmony应用开发—ArkTS-@Observed装饰器和@ObjectLink装饰器:嵌套类对象属性变化

上文所述的装饰器仅能观察到第一层的变化&#xff0c;但是在实际应用开发中&#xff0c;应用会根据开发需要&#xff0c;封装自己的数据模型。对于多层嵌套的情况&#xff0c;比如二维数组&#xff0c;或者数组项class&#xff0c;或者class的属性是class&#xff0c;他们的第二…

MySQL--select count(*)、count(1)、count(列名) 的区别你知道吗?

MySQL select count(*)、count(1)、count(列名) 的区别&#xff1f; 这里我们先给出正确结论&#xff1a; count(*)&#xff0c;包含了所有的列&#xff0c;会计算所有的行数&#xff0c;在统计结果时候&#xff0c;不会忽略列值为空的情况。count(1)&#xff0c;忽略所有的列…