分享一道字节跳动后端面试算法题

题目:

给你一个字符串s,可以将任意一个字符转为任意一个小写字符,这个操作可有m次,问转化后的字符串中最长的相等子串长度。

案例:

s="abcdac" ,m=2,2次操作,可以转化为"abcccc" ,最长是4,返回4。

分析:

题目很好理解,但是如果对算法掌握不是很透彻或者是对滑动窗口、双指针算法学的不是很明白的同学还是有点难度的。字符串的任意字符都可以改变成其他的字符。我们优先考虑滑动窗口双指针来写

定义left和right为左右指针,定义一个字典mp来记录字符串中每个字符出现的次数。遍历一次字符串s,每次循环执行如下,将该下标元素对应的字符+1,如果right-left+1(现在窗口的长度)- mp字典中最大的数(max_value)> m ,说明不可能完成这样的操作,减去当前mp下标元素对应的字符,left+1。再一次执行right-left+1(现在窗口的长度)- mp字典中最大的数(max_value)> m的操作,直接此判断语句不符合。结束后说明right-left+1的字符串满足操作m次将任意一个字符转为任意一个小写字符。与max_length比较取最大值。

mp:保证是字符串s滑动窗口 [left,right] 中字符对应的字符数量

max_value:滑动窗口中字符数量的最大值

max_length:m次操作后最长的相等子串长度

题目代码:

cpp 复制代码
#include<iostream>
#include<unordered_map>
using namespace std;
int main()
{
	string s;
	int m;
	cin>>s;
	cin>>m;
	unordered_map<char,int>mp;
	int left=0;
	int max_lenth=0;
	for(int right=0;right<s.size();right++)
	{
		mp[s[right]]++;
		int max_value=0;
		for(int i=0;i<26;i++)
		{
			char ch='a'+i;
			max_value=max(max_value,mp[ch]);
		}
		while(right-left+1-max_value>m)
		{
			mp[s[left]]--;
			left++;
		}
		max_lenth=max(max_lenth,right-left+1);
	}
	cout<<max_lenth<<endl;
}
相关推荐
意趣新5 分钟前
C 语言源文件从编写完成到最终生成可执行文件的完整、详细过程
c语言·开发语言
TheSumSt19 分钟前
Python丨课程笔记Part3:语法进阶部分(控制结构与基础数据结构)
数据结构·笔记·python
李艺为1 小时前
根据apk包名动态修改Android品牌与型号
android·开发语言
古城小栈1 小时前
Rust变量设计核心:默认不可变与mut显式可变的深层逻辑
算法·rust
电商API&Tina1 小时前
跨境电商 API 对接指南:亚马逊 + 速卖通接口调用全流程
大数据·服务器·数据库·python·算法·json·图搜索算法
XXYBMOOO1 小时前
内核驱动开发与用户级驱动开发:深度对比与应用场景解析
linux·c++·驱动开发·嵌入式硬件·fpga开发·硬件工程
黄河滴滴1 小时前
java系统变卡变慢的原因是什么?从oom的角度分析
java·开发语言
LYFlied2 小时前
【每日算法】LeetCode 1143. 最长公共子序列
前端·算法·leetcode·职场和发展·动态规划
老华带你飞2 小时前
农产品销售管理|基于java + vue农产品销售管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
superman超哥2 小时前
Rust Workspace 多项目管理:单体仓库的优雅组织
开发语言·rust·多项目管理·rust workspace·单体仓库