CF1082B Vova and Trophies 题解

瞎搞题,推荐的,一看是道水题,就随手A了……

题目描述

Vova has won \(n\)trophies in different competitions. Each trophy is either golden or silver. The trophies are arranged in a row.

The beauty of the arrangement is the length of the longest subsegment consisting of golden trophies. Vova wants to swap two trophies (not necessarily adjacent ones) to make the arrangement as beautiful as possible — that means, to maximize the length of the longest such subsegment.

Help Vova! Tell him the maximum possible beauty of the arrangement if he is allowed to do at most one swap.

输入格式

The first line contains one integer \(n( 2 \le n \le 10^5)\) — the number of trophies.

The second line contains \(n\) characters, each of them is either \(G\) or \(S\). If the $ i -th$ character is \(G\), then the \(i -th\) trophy is a golden one, otherwise it's a silver trophy.

输出格式

Print the maximum possible length of a subsegment of golden trophies, if Vova is allowed to do at most one swap.

题解

单调队列

我的想法是从左往右搞一个前缀和,记录一下当前有几个\(G\)

然后我们思考,能让一个\(G\)去替换\(S\)的条件是什么:

是至少有一个\(G\)没被我们选中,如图

想要让倒数第三个格子变成\(G\),就必须有一个其他格子是\(G\),比如\(1\)号格子

那么可以分类讨论一哈子

  1. 如果当前有至少一个\(G\)没被选中,我们就可以容忍在某一段序列里出现少于等于1个\(S\)

如图,绿色是我们已选中的序列,序列外有一\(G\),则可以替换

2.如果当前已选中所有的\(G\),那我们就不能从某个地方抽调一个\(G\)过来替换掉\(S\)

若为该情况则不可以,因为已经没有多余的\(G\)来替换了

那么这个东西的实现我们就可以用一下单调队列

并不需要真的搞个队列,模拟一下就行

首先先设一个指针\(now\)指向零,然后读入

读入的时候如果读入的是\(G\),那么存为\(1\),否则存为\(0\)

这样前缀和数组\(sum[i]\)就可以统计出在\(i\)位置前有多少个\(G\)

\(sum[i] - sum[now]\)就是当前队列里有多少个\(G\)

我们比较与\(sum[i] - sum[now]\)与当前队列里的奖牌数,就可以根据上面说的两种情况做出特判

大水题……

#include<bits/stdc++.h>
using namespace std;
#define rint register int
int n, a[100010], sum[100010], now, ans, tot;
int main( void ){
cin >> n;
char ch;
for( rint i = 1; i <= n; i++ ){
cin >> ch;
if( ch == 'G' ){
a[i] = 1; tot++;
} else a[i] = 0;
sum[i] = sum[i - 1] + a[i];
}
for( rint i = 1; i <= n; i++ ){
if( sum[i] - sum[now] != tot ){
while( sum[i] - sum[now] < i - now - 1 && now <= i ) now++; ans = max( ans, i - now );
}else{
while( sum[i] - sum[now] < i - now && now <= i ) now++; ans = max( ans, i - now );
}
}
cout << ans;
return 0;
}

CF1082B Vova and Trophies 题解的更多相关文章

  1. Codeforces 1082B Vova and Trophies(前缀+后缀)

    题目链接:Vova and Trophies 题意:给定长度为n的字符串s,字符串中只有G和S,只允许最多一次操作:任意位置的两个字符互换.求连续G的最长长度. 题解:维护pre和pr,nxt和nx. ...

  2. Educational Codeforces Round 55:B. Vova and Trophies

    B. Vova and Trophies 题目链接:https://codeforc.es/contest/1082/problem/B 题意: 给出一个“GS”串,有一次交换两个字母的机会,问最大的 ...

  3. Codeforces 1082B Vova and Trophies 模拟,水题,坑 B

    Codeforces 1082B Vova and Trophies https://vjudge.net/problem/CodeForces-1082B 题目: Vova has won nn t ...

  4. Educational Codeforces Round 55 (Rated for Div. 2) B. Vova and Trophies 【贪心 】

    传送门:http://codeforces.com/contest/1082/problem/B B. Vova and Trophies time limit per test 2 seconds ...

  5. Educational Codeforces Round 55 (Rated for Div. 2) B. Vova and Trophies (贪心+字符串)

    B. Vova and Trophies time limit per test2 seconds memory limit per test256 megabytes inputstandard i ...

  6. Educational Codeforces Round 55 (Rated for Div. 2) B. Vova and Trophies

    传送门 https://www.cnblogs.com/violet-acmer/p/10035971.html 题意: Vova有n个奖杯,这n个奖杯全部是金奖或银奖,Vova将所有奖杯排成一排,你 ...

  7. Vova and Trophies CodeForces - 1082B(思维题)

    Vova has won nn trophies in different competitions. Each trophy is either golden or silver. The trop ...

  8. B. Vova and Trophies 字符串预处理+思维+贪心

    题意:给出一个字符串 只有G和S  可以交换任意两个位置的字符一次 问 最长的G的长度是多少 思路:预处理字符串 把相同的G粘成一个G 记一下数量  字符串变为 GSSGSGGSGSSG 相邻有一个S ...

  9. B. Vova and Trophies

    链接 [https://codeforces.com/contest/1082/problem/B] 题意 给你一个包含GS的字符串,只允许交换一次任意不同位置的字符,问最长的连续G串是多少 分析 很 ...

随机推荐

  1. mongo的基本命令操作

    基本用法学习:https://www.runoob.com/mongodb/mongodb-create-database.html MongoDB数据库基本用法 show dbs:显示数据库列表 s ...

  2. rancher2.0快速入门

    注意:本入门指南的目的是让您快速的运行一个Rancher2.0环境,它不适用于生产.有关更全面的说明,请查阅Rancher安装. 本教程将指导您完成: 安装Rancher v2.0 : 创建第一个集群 ...

  3. Spring Boot 学习笔记(六) 整合 RESTful 参数传递

    Spring Boot 学习笔记 源码地址 Spring Boot 学习笔记(一) hello world Spring Boot 学习笔记(二) 整合 log4j2 Spring Boot 学习笔记 ...

  4. box-sizing: border-box

    如果在元素上设置了 box-sizing: border-box; 则 padding(内边距) 和 border(边框) 也包含在 width 和 height 中

  5. Kubernetes集群部署DNS插件

    准备 kube-dns 相关镜像 准备 kube-dns 相关 yaml 文件 系统预定义的 RoleBinding 配置 kube-dns 相关服务 检查 kube-dns 功能 kube-dns ...

  6. Hackintosh Of Lenovo R720 15IKBN

    Hackintosh Of Qftm 一个黑苹果爱好者的项目 定制:macOS Catalina 10.15.1 电脑配置 一键查看电脑配置(鲁大师.360驱动管理.Lenovo管家等) 规格 详细信 ...

  7. 恭喜你,Get到一份 正则表达式 食用指南

    先赞后看,养成习惯 前言 正则表达式 正则表达式: 定义一个搜索模式的字符串. 正则表达式可以用于搜索.编辑和操作文本. 正则对文本的分析或修改过程为:首先正则表达式应用的是文本字符串(text/st ...

  8. 将mysql数据库集成到idea中

    将mysql数据库集成到idea中

  9. spring——AOP原理及源码(三)

    在上一篇中,我们创建并在BeanFactory中注册了AnnotationAwareAspectJAutoProxyCreator组件.本篇我们将要探究,这个组件是在哪里以及何时发挥作用的. 调试的起 ...

  10. 在eclipse的Java类文件中,右上角出现大写字母A代表什么

    代表这个文件(类)是一个抽象类abstract的第一个字母: