[2021.11.19]UPC-2021级新生个人训练赛第4场-19276 Problem B ok 字符串

2024-04-14 18:32

本文主要是介绍[2021.11.19]UPC-2021级新生个人训练赛第4场-19276 Problem B ok 字符串,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

商场中展示了这么多玩具,乐乐爱不释手。现在游戏环节开始,只要你能解决一个问题,就能够挑选一件精美的玩具。此时,乐乐需要你们这帮“牛娃”的帮助,请你帮助乐乐解决这个问题。 
现在给你一个长度为 n 的字符串,该字符串只包含字符’o’和’k’。你最多可以修改 t 个字符(将字符’o’改为字符’k’或将字符’k’改为字符’o’),使得某一段连续相同的字符个数是最多的。
例如:  ‘ooooo’或’kkkkk’像这样的连续相同字符都可以。 
请你经过不多于t次地合理修改,帮助乐乐求出字符串某一段连续相同的字符最多个数。

输入

第一行输入整数 n 和 t,分别表示字符串的总长度和最多可以修改的字符数。 
第二行输入一行字符串,仅包含字符‘o‘或‘k‘。

输出

输出一个整数,表示经过不多于 t 次地合理修改,字符串某一段连续相同的字符最多个数

样例输入 Copy

【样例1】
4 2 
okko 
【样例2】
8 3 
ookookoo 

样例输出 Copy

【样例1】
4
【样例2】
8

提示

样例一:通过 2 次修改后,可以获得字符串‘oooo‘或‘kkkk‘,所以连续的字符个数是 4。 
样例二:虽然 t 是 3,但只需通过 2 次修改后,可以获得字符串‘oooooooo‘,连续的字符个数是 8。 

对于 80%的数据,保证 1<=n<=10000,0<=t<=n。 
对于另外 20%的数据,保证 n<=1000000, 0<=t<=10000,并保证字符‘o‘的总个数<=10000
或字符‘k‘的总个数<=10000。 

我这个做法属实复杂了!: ( 

但好像大家思路都大致相同~:从前到后遍历字符串,(我这个是从后到前)记录o和k出现的次数

如果修改次数足以让当前所遍历的字符串变成连续的,就继续往下遍历,记录下当前字符串长度,再与所记录的最大长度进行比较。

如果不能让当前字符串变为连续的,就从前往后缩减字符串长度,直至修改次数可以使当前字符串变为连续的,记录下当前字符串长度,再与所记录的最大长度进行比较。

通过这个思路,大家应该能轻松编出比我简单得多得多的代码 ;),或者直接在CSDN里搜往届学长的代码也行~

以下是我的代码 : )

#include <cstdio>
using namespace std;
int c[1000010];    //c[i]用于记录从0到i为止o和k字符出现的次数
int main(){char a;int n,j,k,i,ans=1;scanf("%d %d",&n,&k);scanf(" %c",&a);if(a=='o')c[0]=1;        //若为o  则为1elsec[0]=-1;        //若为k  则为-1for(i=1;i<n;i++){scanf("%c",&a);if(a=='o')c[i]=c[i-1]+1;elsec[i]=c[i-1]-1;  }for(i=n-1;i>=ans;i--)    //当i<=当前所记录的最大的经修改后的连续字符串长度时退出循环for(j=-1;j<i;j++){    //因为不可能得到更长的连续字符串了if (j == -1) {    //j为-1时 说明不需要缩减长度,if (c[i]+2*k>=i+1 || c[i]- 2*k<=-(i+1)){  //判断是否可以修改为连续字符串if (i - j + 1 > ans){  ans = i + 1;}break;}}else {    if (c[i] - c[j] + 2*k >= i - j|| c[i] - c[j] - 2*k <= -(i-j)) {if (i - j > ans){ans = i - j;}break;};}}printf("%d ",ans);return 0;
}

U

这篇关于[2021.11.19]UPC-2021级新生个人训练赛第4场-19276 Problem B ok 字符串的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

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

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

Java实现时间与字符串互相转换详解

《Java实现时间与字符串互相转换详解》这篇文章主要为大家详细介绍了Java中实现时间与字符串互相转换的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、日期格式化为字符串(一)使用预定义格式(二)自定义格式二、字符串解析为日期(一)解析ISO格式字符串(二)解析自定义

python中字符串拼接的几种方法及优缺点对比详解

《python中字符串拼接的几种方法及优缺点对比详解》在Python中,字符串拼接是常见的操作,Python提供了多种方法来拼接字符串,每种方法有其优缺点和适用场景,以下是几种常见的字符串拼接方法,需... 目录1. 使用 + 运算符示例:优缺点:2. 使用&nbsjsp;join() 方法示例:优缺点:3

java字符串数字补齐位数详解

《java字符串数字补齐位数详解》:本文主要介绍java字符串数字补齐位数,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java字符串数字补齐位数一、使用String.format()方法二、Apache Commons Lang库方法三、Java 11+的St

C++字符串提取和分割的多种方法

《C++字符串提取和分割的多种方法》在C++编程中,字符串处理是一个常见的任务,尤其是在需要从字符串中提取特定数据时,本文将详细探讨如何使用C++标准库中的工具来提取和分割字符串,并分析不同方法的适用... 目录1. 字符串提取的基本方法1.1 使用 std::istringstream 和 >> 操作符示

C语言字符函数和字符串函数示例详解

《C语言字符函数和字符串函数示例详解》本文详细介绍了C语言中字符分类函数、字符转换函数及字符串操作函数的使用方法,并通过示例代码展示了如何实现这些功能,通过这些内容,读者可以深入理解并掌握C语言中的字... 目录一、字符分类函数二、字符转换函数三、strlen的使用和模拟实现3.1strlen函数3.2st

Java反转字符串的五种方法总结

《Java反转字符串的五种方法总结》:本文主要介绍五种在Java中反转字符串的方法,包括使用StringBuilder的reverse()方法、字符数组、自定义StringBuilder方法、直接... 目录前言方法一:使用StringBuilder的reverse()方法方法二:使用字符数组方法三:使用自

Golang中拼接字符串的6种方式性能对比

《Golang中拼接字符串的6种方式性能对比》golang的string类型是不可修改的,对于拼接字符串来说,本质上还是创建一个新的对象将数据放进去,主要有6种拼接方式,下面小编就来为大家详细讲讲吧... 目录拼接方式介绍性能对比测试代码测试结果源码分析golang的string类型是不可修改的,对于拼接字

使用DeepSeek搭建个人知识库(在笔记本电脑上)

《使用DeepSeek搭建个人知识库(在笔记本电脑上)》本文介绍了如何在笔记本电脑上使用DeepSeek和开源工具搭建个人知识库,通过安装DeepSeek和RAGFlow,并使用CherryStudi... 目录部署环境软件清单安装DeepSeek安装Cherry Studio安装RAGFlow设置知识库总

Java对象和JSON字符串之间的转换方法(全网最清晰)

《Java对象和JSON字符串之间的转换方法(全网最清晰)》:本文主要介绍如何在Java中使用Jackson库将对象转换为JSON字符串,并提供了一个简单的工具类示例,该工具类支持基本的转换功能,... 目录前言1. 引入 Jackson 依赖2. 创建 jsON 工具类3. 使用示例转换 Java 对象为