Codeforces Round #354 (Div. 2) - C. Vasya and String

2024-01-23 23:38

本文主要是介绍Codeforces Round #354 (Div. 2) - C. Vasya and String,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

                                                C. Vasya and String

题目链接:http://codeforces.com/problemset/problem/676/C

Description

High school student Vasya got a string of length n as a birthday present. This string consists of letters 'a' and 'b' only. Vasya denotes beauty of the string as the maximum length of a substring (consecutive subsequence) consisting of equal letters.

Vasya can change no more than k characters of the original string. What is the maximum beauty of the string he can achieve?

Input

The first line of the input contains two integers n and k (1 ≤ n ≤ 100 000, 0 ≤ k ≤ n) — the length of the string and the maximum number of characters to change.

The second line contains the string, consisting of letters 'a' and 'b' only.

Output

Print the only integer — the maximum beauty of the string Vasya can achieve by changing no more than k characters.

Sample Input

4 2
abba

Sample Output

4

题意:有一个只包含ab的字符串,长度为n(n<=100000),你可以改变任意一个字符k(0<=k<=n),求最长的都是同一字符的字符串的长度。

题解:分别统计a和b的前缀和,前缀和的差值就是当前长度需要修改的次数,二分距离看看是否符合K次即可。

AC代码:

#include<cstdio>
#include<algorithm>
using namespace std;
const int maxn = 100007;
char s[maxn];
int sum[maxn];
int n,m;
int main()
{scanf("%d%d",&n,&m);scanf("%s",s+1);int Ans = 1;int Ans2 = 1;for(int i=1;i<=n;i++){sum[i]=sum[i-1];if(s[i]=='b')sum[i]++;}for(int i=1;i<=n;i++){int ans = 0;int l = i;int r = n;while(l<r){int mid = (l+r+1)/2;if(sum[mid]-sum[i]<=m){l=mid;}else r = mid - 1;ans = l;}if(sum[ans]-sum[i-1]<=m)Ans = max(ans-i+1,Ans);else Ans = max(ans-i,Ans);}//printf("%d",Ans);for(int i=1;i<=n;i++){sum[i]=sum[i-1];if(s[i]=='a')sum[i]++;}for(int i=1;i<=n;i++){int ans = 0;int l = i;int r = n;while(l<r){int mid = (l+r+1)/2;if(sum[mid]-sum[i]<=m){l=mid;}else r = mid - 1;ans = l;}if(sum[ans]-sum[i-1]<=m)Ans2 = max(ans-i+1,Ans2);else Ans2 = max(ans-i,Ans2);}// printf("%d",Ans2);printf("%d\n",max(Ans2,Ans));return 0;
}


这篇关于Codeforces Round #354 (Div. 2) - C. Vasya and String的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C++ STL-string类底层实现过程

《C++STL-string类底层实现过程》本文实现了一个简易的string类,涵盖动态数组存储、深拷贝机制、迭代器支持、容量调整、字符串修改、运算符重载等功能,模拟标准string核心特性,重点强... 目录实现框架一、默认成员函数1.默认构造函数2.构造函数3.拷贝构造函数(重点)4.赋值运算符重载函数

redis数据结构之String详解

《redis数据结构之String详解》Redis以String为基础类型,因C字符串效率低、非二进制安全等问题,采用SDS动态字符串实现高效存储,通过RedisObject封装,支持多种编码方式(如... 目录一、为什么Redis选String作为基础类型?二、SDS底层数据结构三、RedisObject

Java获取当前时间String类型和Date类型方式

《Java获取当前时间String类型和Date类型方式》:本文主要介绍Java获取当前时间String类型和Date类型方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录Java获取当前时间String和Date类型String类型和Date类型输出结果总结Java获取

java String.join()方法实例详解

《javaString.join()方法实例详解》String.join()是Java提供的一个实用方法,用于将多个字符串按照指定的分隔符连接成一个字符串,这一方法是Java8中引入的,极大地简化了... 目录bVARxMJava String.join() 方法详解1. 方法定义2. 基本用法2.1 拼接

Java字符串处理全解析(String、StringBuilder与StringBuffer)

《Java字符串处理全解析(String、StringBuilder与StringBuffer)》:本文主要介绍Java字符串处理全解析(String、StringBuilder与StringBu... 目录Java字符串处理全解析:String、StringBuilder与StringBuffer一、St

Java String字符串的常用使用方法

《JavaString字符串的常用使用方法》String是JDK提供的一个类,是引用类型,并不是基本的数据类型,String用于字符串操作,在之前学习c语言的时候,对于一些字符串,会初始化字符数组表... 目录一、什么是String二、如何定义一个String1. 用双引号定义2. 通过构造函数定义三、St

Java中的String.valueOf()和toString()方法区别小结

《Java中的String.valueOf()和toString()方法区别小结》字符串操作是开发者日常编程任务中不可或缺的一部分,转换为字符串是一种常见需求,其中最常见的就是String.value... 目录String.valueOf()方法方法定义方法实现使用示例使用场景toString()方法方法

C#数据结构之字符串(string)详解

《C#数据结构之字符串(string)详解》:本文主要介绍C#数据结构之字符串(string),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录转义字符序列字符串的创建字符串的声明null字符串与空字符串重复单字符字符串的构造字符串的属性和常用方法属性常用方法总结摘

如何解决mysql出现Incorrect string value for column ‘表项‘ at row 1错误问题

《如何解决mysql出现Incorrectstringvalueforcolumn‘表项‘atrow1错误问题》:本文主要介绍如何解决mysql出现Incorrectstringv... 目录mysql出现Incorrect string value for column ‘表项‘ at row 1错误报错

java String.join()的使用小结

《javaString.join()的使用小结》String.join()是Java8引入的一个实用方法,用于将多个字符串按照指定分隔符连接成一个字符串,本文主要介绍了javaString.join... 目录1. 方法定义2. 基本用法2.1 拼接多个字符串2.2 拼接集合中的字符串3. 使用场景和示例3