CF1082B Vova and Trophies 题解
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\)号格子
那么可以分类讨论一哈子
- 如果当前有至少一个\(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 题解的更多相关文章
- Codeforces 1082B Vova and Trophies(前缀+后缀)
题目链接:Vova and Trophies 题意:给定长度为n的字符串s,字符串中只有G和S,只允许最多一次操作:任意位置的两个字符互换.求连续G的最长长度. 题解:维护pre和pr,nxt和nx. ...
- Educational Codeforces Round 55:B. Vova and Trophies
B. Vova and Trophies 题目链接:https://codeforc.es/contest/1082/problem/B 题意: 给出一个“GS”串,有一次交换两个字母的机会,问最大的 ...
- Codeforces 1082B Vova and Trophies 模拟,水题,坑 B
Codeforces 1082B Vova and Trophies https://vjudge.net/problem/CodeForces-1082B 题目: Vova has won nn t ...
- 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 ...
- 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 ...
- 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将所有奖杯排成一排,你 ...
- Vova and Trophies CodeForces - 1082B(思维题)
Vova has won nn trophies in different competitions. Each trophy is either golden or silver. The trop ...
- B. Vova and Trophies 字符串预处理+思维+贪心
题意:给出一个字符串 只有G和S 可以交换任意两个位置的字符一次 问 最长的G的长度是多少 思路:预处理字符串 把相同的G粘成一个G 记一下数量 字符串变为 GSSGSGGSGSSG 相邻有一个S ...
- B. Vova and Trophies
链接 [https://codeforces.com/contest/1082/problem/B] 题意 给你一个包含GS的字符串,只允许交换一次任意不同位置的字符,问最长的连续G串是多少 分析 很 ...
随机推荐
- python--mysql的CURD操作
from pymysql import * def main(): # 创建Connextion连接 conn = connect(host='localhost', port=3306, user= ...
- 关于php自学
自己本人现在正在自学php有一段时间了,不知道现在的学习状态咋样,在我看来应该属于不算很糟糕,但有点糟糕的状态. 如果算学习自学php的话,现在断断续续应该是有5个月了,按理说是差不多可以做出独立项目 ...
- <JZOJ5944>信标
emmm树形dp?好像是的 搬一个题解证明过来 由于在n>1时答案至少为1,我们枚举一个必须放的根, 所有深度不同的点就被区分开了. 设一个节点有c个儿子, 发现必须在其中至少c−1个儿子的子树 ...
- SPA(单页面web应用)和MPA(多页面web应用)的区别
转:https://blog.csdn.net/amaniz/article/details/79203562 vue多页面应用开发请参见: https://github.com/amunamuna/ ...
- 为啥Waymo和Uber间的官司,这么难界定?
自动驾驶作为被众多巨头和创业者看好的技术及领域,已有众多企业涉足其中.在自动驾驶尚未完全落地.制定统一标准前,每家企业都在争分夺秒地进行研发,试图率先抢占自动驾驶的高地.毕竟一旦成功,就能够创造巨大的 ...
- python socket实例
1.客户端向服务端发送 #coding:utf-8 '''客户端''' import socket khd=socket.socket() #声明socket类型,同时生产socket连接对象 khd ...
- 烧光百亿的共享单车行业,ofo和摩拜到底该不该合并?
共享经济领域可谓一地鸡毛,除了众多不靠谱的跟风项目外--共享马扎."老公寄存屋",更多的是不绝于耳的倒闭消息.尤其是在共享单车行业,暂且不提那些体量小的项目,单单是倒闭的大型共享单 ...
- BeWhatever
Hadoop Distributed File System:分布式文件系统. HDFS基于流数据模式访问和处理超大文件需求开发,具有高容错性,高可靠性,高可扩展性,多部署在低成本的硬件上.HDFS提 ...
- Git学习笔记(二) · 非典型性程序猿
远程库的使用 前面说到的都是git在本地的操作,那么实际协作开发过程中我们肯定是要有一个远程版本库作为项目的核心版本库,也就是投入生产使用的版本.这里我们以 Github为例.Github是一个开放的 ...
- mongodb游标快照
示例代码 1. 初始数据 > db.snapshot_test.find() { "_id" : ObjectId("560ba37c694895b2de42254 ...