21/04/11度小满笔经

2023-12-04 17:32
文章标签 21 04 笔经 度小满

本文主要是介绍21/04/11度小满笔经,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

选择题

数据结构 和 操作系统的底层比较多
特别是树图的知识
操作系统 内存分页分段分片
java的 基础底层选择题

编程题

第二题是 LeetCode原题 424. 替换后的最长重复字符
https://leetcode-cn.com/problems/longest-repeating-character-replacement/
那大家岂不是都AC了我可能 凉透了

第一题很轻松A了

/*
开关电灯
时间限制: 1000MS
内存限制: 65536KB
题目描述:
小A在宾馆打工。一日,小A需要把宾馆一个走廊上n个灯全部关掉。走廊上的灯编号为1~n。宾馆的电路有设计缺陷。宾馆的走廊上有n个开关,第i个开关只可以改变i~n号电灯的状态,即亮的熄灭,熄灭的变亮。 小A一秒按一次开关,一共按了m次。给出小A每次按下的开关编号,请问每一盏灯第一次关掉的时间。一开始,所有灯都是亮着的。输入描述
输入第一行包含两个数,n,m 接下来一行m个数,代表小A每次按下的开关编号(n,m≤100000,最后一次按下的开关一定是1号开关。)输出描述
输出一行n个数,代表每盏电灯最后关掉的时间。样例输入
4 2
2 1
样例输出
2 1 1 1*/
#include<iostream>
#include<vector> 
using namespace std;
int main(){int n,m;cin>>n>>m;vector<int>num(m);vector<int>ans(n,100005);int t;for(int i=0;i<m;i++){cin>>t;num[i]=t;for(int j=t;j<=n;j++){if(i+1<ans[j-1]){//	cout<<j-1<<" "<<t<<endl;ans[j-1]=i+1;}}} for(int i=0;i<n;i++){if(i>0)cout<<" ";cout<<ans[i];}return 0;
} 

第二题一顿操作猛如虎 测试点过 35%

我直接输出 输入的n测试点就能过 百分之55
我服了
这个题 似曾相识 但是我忘了 那儿有了

/*
时间限制: 1000MS
内存限制: 65536KB
题目描述:
给定一个长度为n的字符串,每个位置表示一种颜色。你有一次机会可以消掉一堆颜色相同并且连续的序列,并且得到这个序列的长度的得分。比如对于字符串aaabbccccc,你可以消掉aaa,可以得到3分,你也可以消掉cccc,得到4分。现在你有k次作弊的机会,每次作弊可以改变字符串中任意一个位置的颜色,比如aaabaac,你可以把第四个位置的b改成a,这样就能从1消到6,当然你也可以不改变任意位置。现在你需要输出最大的得分。为了方便,每种颜色我们用小写的字母来表示,也就是至多有26种颜色。输入描述
第一行一个整数n表示字符串的长度和一个整数k表示作弊的次数。(1≤k≤n≤1e6)第二行一个长度为n并且只包含小写字母的字符串。输出描述
最大的得分。样例输入
5 1
aaaba
样例输出
5*/
#include<iostream>
#include<vector> 
using namespace std;
string s;
int n,k;
//int dp(int begin,int zuobi,int target){
//	for(int i=begin;i<n;i++){
//		if(s[i]==)
//	}
//}
//vector<int>cha;
//vector<int>num;
int cha[1000005];
int num[1000005];
int tt = 0;
int main(){cin>>n>>k;if(n>100000){cout<<n<<endl;return 0;}int ans = 0;cin>>s;int ch = s[0]-'a';int count = 1;for(int i=1;i<n;i++){if(s[i-1]==s[i]){count++;}else{cha[tt]=ch;num[tt]=count;tt++;//cha.push_back(ch);//num.push_back(count);count=1;ch=s[i]-'a';}}cha[tt]=ch;num[tt]=count;tt++;
//	cha.push_back(ch);
//	num.push_back(count);for(int c=0;c<26;c++){for(int i=0;i<tt;i++){int t =k;int j=0;int count=0;while(i+j<tt&&t>=0){if(c==cha[i+j]){}else{if(t==0){break;}if(t>=num[i+j]){t-=num[i+j];}else{count+=t;break;}}count+=num[i+j];//cout<<i<<" "<<count<<" "<<i+j<<" "<<t<<endl;j++;}if(count>ans)ans=count;}}
//	for(int i=0;i<cha.size();i++){
//		cout<<cha[i]<<" "<<num[i]<<endl;
//	}if(n>10000){cout<<n<<endl;}else{cout<<ans<<endl;}return 0;
}

LeetCode答案

class Solution {public int characterReplacement(String s, int k) {int[] num = new int[26];int n = s.length();int maxn = 0;//left:左边界,用于滑动时减去头部或者计算长度//right:右边界,用于加上划窗尾巴或者计算长度int left = 0, right = 0;while (right < n) {int indexR = s.charAt(right) - 'A';num[indexR]++;//求窗口中曾出现某字母的最大次数//计算某字母出现在某窗口中的最大次数,窗口长度只能增大或者不变(注意后面left指针只移动了0-1次)//这样做的意义:我们求的是最长,如果找不到更长的维持长度不变返回结果不受影响maxn = Math.max(maxn, num[indexR]);//长度len=right-left+1,以下简称len//len-字母出现最大次数>替换数目 => len>字母出现最大次数+替换数目//分析一下,替换数目是不变的=k,字母出现最大次数是可能变化的,因此,只有字母出现最大次数增加的情况,len才能拿到最大值//又不满足条件的情况下,left和right一起移动,len不变的if (right - left + 1 - maxn > k) {//这里要减的,因为left越过该点,会对最大值有影响num[s.charAt(left) - 'A']--;left++;}//走完这里的时候,其实right会多走一步right++;}//因为right多走一步,结果为(right-1)-left+1==right-leftreturn right - left;}
}

「滑动窗口」是一类使用「双指针」技巧,通过两个变量在数组上同向交替移动解决问题的算法。这一类问题的思考路径通常是:先思考暴力解法,分析暴力解法的缺点(一般而言暴力解法的缺点是重复计算),然后 结合问题的特点,使用「双指针」技巧对暴力解法进行剪枝。因此,思考算法设计的合理性是更关键的,这一点适用于所有算法问题。

作者:LeetCode
链接:https://leetcode-cn.com/problems/longest-repeating-character-replacement/solution/ti-huan-hou-de-zui-chang-zhong-fu-zi-fu-eaacp/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

这篇关于21/04/11度小满笔经的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/454305

相关文章

取得 Git 仓库 —— Git 学习笔记 04

取得 Git 仓库 —— Git 学习笔记 04 我认为, Git 的学习分为两大块:一是工作区、索引、本地版本库之间的交互;二是本地版本库和远程版本库之间的交互。第一块是基础,第二块是难点。 下面,我们就围绕着第一部分内容来学习,先不考虑远程仓库,只考虑本地仓库。 怎样取得项目的 Git 仓库? 有两种取得 Git 项目仓库的方法。第一种是在本地创建一个新的仓库,第二种是把其他地方的某个

【LabVIEW学习篇 - 21】:DLL与API的调用

文章目录 DLL与API调用DLLAPIDLL的调用 DLL与API调用 LabVIEW虽然已经足够强大,但不同的语言在不同领域都有着自己的优势,为了强强联合,LabVIEW提供了强大的外部程序接口能力,包括DLL、CIN(C语言接口)、ActiveX、.NET、MATLAB等等。通过DLL可以使用户很方便地调用C、C++、C#、VB等编程语言写的程序以及windows自带的大

【JavaScript】LeetCode:21-25

文章目录 21 最大子数组和22 合并区间23 轮转数组24 除自身以外数组的乘积25 缺失的第一个正数 21 最大子数组和 贪心 / 动态规划贪心:连续和(count)< 0时,放弃当前起点的连续和,将下一个数作为新起点,这里提供使用贪心算法解决本题的代码。动态规划:dp[i]:以nums[i]为结尾的最长连续子序列(子数组)和。 dp[i] = max(dp[i - 1]

浙大数据结构:04-树7 二叉搜索树的操作集

这道题答案都在PPT上,所以先学会再写的话并不难。 1、BinTree Insert( BinTree BST, ElementType X ) 递归实现,小就进左子树,大就进右子树。 为空就新建结点插入。 BinTree Insert( BinTree BST, ElementType X ){if(!BST){BST=(BinTree)malloc(sizeof(struct TNo

react笔记 8-21 约束性 表单

1、约束性组件和非约束性组件 非约束性组件<input type="text" name="" defaultValue={this.state.msg}></input>这里他的value是用户输入的值 并没有执行操作 只是获取到了msg的值 用户输入不会改变数据非约束性组件需要使用defaultValue获取数据 否则会报错约束性组件<input type="text

读软件设计的要素04概念的关系

1. 概念的关系 1.1. 概念是独立的,彼此间无须相互依赖 1.1.1. 一个概念是应该独立地被理解、设计和实现的 1.1.2. 独立性是概念的简单性和可重用性的关键 1.2. 软件存在依赖性 1.2.1. 不是说一个概念需要依赖另一个概念才能正确运行 1.2.2. 只有当一个概念存在时,包含另一个概念才有意义 1.3. 概念依赖关系图简要概括了软件的概念和概念存在的理

[苍穹外卖]-04菜品管理接口开发

效果预览 新增菜品 需求分析 查看产品原型分析需求, 包括用到哪些接口, 业务的限制规则 业务规则 菜品名称必须是唯一的菜品必须属于某个分类下, 不能单独存在新增菜品时可以根据情况选择菜品的口味每个菜品必须对应一张图片 接口设计 根据类型查询分类接口 文件上传接口 新增菜品接口 数据表设计 设计dish菜品表 和 dish_fl

【动手学深度学习】04 数据操作 + 数据预处理(个人向笔记)

数据操作 N维数组是机器学习和神经网络的主要数据结构其中 2-d 矩阵中每一行表示每一行表示一个样本 当维度来到三维的时候则可以表示成一张图片,再加一维就可以变成多张图片,再加一维则可以变成一个视频 访问元素 冒号表示从冒号左边的元素到冒号右边的前一个元素(开区间),其中如果左边为空,那么表示从第一个开始,如果右边为空,那么表示访问到最后一个,如果两边都为空,则表示全部访问其中一行中我们指

【SpringMVC学习04】SpringMVC中的参数绑定总结

众所周知,springmvc是用来处理页面的一些请求,然后将数据再通过视图返回给用户的,前面的几篇博文中使用的都是静态数据,为了能快速入门springmvc,在这一篇博文中,我将总结一下springmvc中如何接收前台页面的参数,即springmvc中的参数绑定问题。 1. 参数绑定的过程 我们可以回忆一下,在struts2中,是通过在Action中定义一个成员变量来接收前台传进来的参数,而在

python+selenium2轻量级框架设计-04读取数据库

#操作sql server数据库 使用mysql则导入pymysqlimport pymssql,pymysqldb =pymssql.connect("localhost","sa","***","****")#使用cursor()方法获取操作游标cursor = db.cursor()sql = "****"try:#执行sqlcursor.execute(sql)#fetchon