ACM: 限时训练题解-Rock-Paper-Scissors-前缀和
- Rock-Paper-Scissors
Rock-Paper-Scissors is a two-player game, where each player chooses one of Rock, Paper, or Scissors. Here are the three cases in which a player gets one point:
Choosing Rock wins over a player choosing scissors.
Choosing Scissors wins over a player choosing Paper.
Choosing Paper wins over a player choosing Rock.
In all other cases, the player doesn’t get any points.
Bahosain and his friend Bayashout played N rounds of this game. Unlike Bayashout, Bahosain was too lazy to decide what to play next for each round, so before starting to play, he chose three integers X Y Z such that X+Y+Z = N and X, Y, Z ≥ 0, and then played Rock for the first X rounds, Paper for the next Y rounds, and Scissors for the last Z rounds.
Bayashout got more points in the N rounds and won. Given the moves played by Bayashout in each round, Bahosain wants to know the number of ways in which he could have chosen X, Y and Z such that he wins in the N rounds.
The winner of the N rounds is the player that gets more total points in the N rounds.
Input
The first line of input contains T (1 ≤ T ≤ 64), where T is the number of test cases.
The first line of each test case contains an integer N (1 ≤ N ≤ 1000) that represents the number of rounds.
The next line contains a string of N uppercase letters, the first letter represents the choice of Bayashout for the first round, the second letter represents his choice for the second round, and so on.
Each letter in the string is one of the following: R (Rock), P (Paper), or S (Scissors).
Output
For each test case, print a single line with the number of ways in which Bahosain could have won.
|
Sample Input |
Sample Output |
|
4 |
3 |
|
3 |
1 |
|
RPS |
1 |
|
1 |
5 |
|
R |
|
|
5 |
|
|
PPRSR |
|
|
5 |
|
|
RPSPR |
/*
题意;A B猜拳,猜N次
但是A很懒,不想去想怎么猜拳就随机的连续出x次石头 y次布 z次剪刀
现在给出B的猜拳的出拳的顺序,
然后A以石头R 布P 剪刀S 的顺序出,在出了布之后就不在出石头,出了剪刀后就不再出石头和布
问A有多少种可能赢B。 这题一开始不怎么会做,做到限时赛最后还有30分钟的时候又回过头来看这个题目
不就是一个简单的前缀和么,一开始都没想到。 AC代码:
*/
#include"iostream"
#include"algorithm"
#include"cstdio"
#include"cstring"
#include"cmath"
#define MX 1000 + 50
using namespace std;
int r[MX],p[MX],s[MX],len;
char str[MX]; int main() {
int T;
scanf("%d",&T);
while(T--) {
memset(r,0,sizeof(r));
memset(p,0,sizeof(p));
memset(s,0,sizeof(s));
memset(str,0,sizeof(str));
scanf("%d%s",&len,str+1);
for(int i=1; i<=len; i++) {
if(str[i]=='R') { //这里用数组rps记录全部出石头布剪刀的得分 【dp-前缀和】
p[i]=p[i-1]+1; //如果B出的石头 则A的布得分 +1
r[i]=r[i-1]; //A的石头平局,不变
s[i]=s[i-1]-1; //A的剪刀输扣分 -1
} //下面一样
if(str[i]=='S') {
r[i]=r[i-1]+1;
s[i]=s[i-1];
p[i]=p[i-1]-1;
}
if(str[i]=='P') {
s[i]=s[i-1]+1;
p[i]=p[i-1];
r[i]=r[i-1]-1;
}
}
int ans=0;
for(int i=0; i<=len; i++) { //i-1 为连续出石头的次数 r[i]-r[0]为A出石头的得分
for(int j=i; j<=len; j++) { //j-i为连续出布的次数 p[j]-p[i]为A出布的得分
if(r[i]-r[0]+p[j]-p[i]+s[len]-s[j]>0) { //len-j 为连续出布的次数 s[len]-p[j]为A出剪刀的得分
ans++; //计算和 如果比0大就算赢。
}
}
}
printf("%d\n",ans);
}
return 0;
}
ACM: 限时训练题解-Rock-Paper-Scissors-前缀和的更多相关文章
- ACM: 限时训练题解-Runtime Error-二分查找
Runtime Error Bahosain was trying to solve this simple problem, but he got a Runtime Error on one ...
- ACM: 限时训练题解-Heavy Coins-枚举子集-暴力枚举
Heavy Coins Bahosain has a lot of coins in his pocket. These coins are really heavy, so he always ...
- ACM: 限时训练题解- Travelling Salesman-最小生成树
Travelling Salesman After leaving Yemen, Bahosain now works as a salesman in Jordan. He spends mos ...
- ACM: 限时训练题解-Epic Professor-水题
Epic Professor Dr. Bahosain works as a professor of Computer Science at HU (Hadramout Universit ...
- ACM: 限时训练题解-Street Lamps-贪心-字符串【超水】
Street Lamps Bahosain is walking in a street of N blocks. Each block is either empty or has one la ...
- 2018 ACM-ICPC 中国大学生程序设计竞赛线上赛 H题 Rock Paper Scissors Lizard Spock.(FFT字符串匹配)
2018 ACM-ICPC 中国大学生程序设计竞赛线上赛:https://www.jisuanke.com/contest/1227 题目链接:https://nanti.jisuanke.com/t ...
- 【题解】CF1426E Rock, Paper, Scissors
题目戳我 \(\text{Solution:}\) 考虑第二问,赢的局数最小,即输和平的局数最多. 考虑网络流,\(1,2,3\)表示\(Alice\)选择的三种可能性,\(4,5,6\)同理. 它们 ...
- 题解 CF1426E - Rock, Paper, Scissors
一眼题. 第一问很简单吧,就是每个 \(\tt Alice\) 能赢的都尽量让他赢. 第二问很简单吧,就是让 \(\tt Alice\) 输的或平局的尽量多,于是跑个网络最大流.\(1 - 3\) 的 ...
- SDUT 3568 Rock Paper Scissors 状压统计
就是改成把一个字符串改成三进制状压,然后分成前5位,后5位统计, 然后直接统计 f[i][j][k]代表,后5局状压为k的,前5局比和j状态比输了5局的有多少个人 复杂度是O(T*30000*25*m ...
随机推荐
- Android 快速开发框架:推荐10个框架:afinal、ThinkAndroid、andBase、KJFrameForAndroid、SmartAndroid、dhroid..
对于Android初学者以及对于我们菜鸟,这些大神们开发的轻量级框架非常有用(更别说开源的了). 下面转载这10个框架的介绍:(按顺序来吧没有什么排名). 一. Afinal 官方介绍: Afina ...
- wp8 入门到精通 定时更新瓷贴
public class ScheduledAgent : ScheduledTaskAgent { static ScheduledAgent() { Deployment.Current.Disp ...
- 二叉搜索树的实现及指针问题的一点思考(C++)
今天实现二叉搜索树的时候因为指针的问题卡了一上午(实在不应该...),一直segmentation fault,个人感觉还是需要记录一下的. 首先贴一下做的题的意思: 输入一系列整数,建立二叉排序数, ...
- [WebService] the namespace on the "definitions" element, is not a valid SOAP version
公司对外通过webservice访问别人接口,对方webservice IP地址发生变化,切换过去之后,始终报错,在网上搜索了各种办法之后,暂时总结该问题几种可能解决办法,待真正解决时用的到. 异常详 ...
- 安装wine的问题
- Android LayoutInflater详解 (转)
在实际开发中LayoutInflater这个类还是非常有用的,它的作用类似于findViewById().不同点是LayoutInflater是用来找res/layout/下的xml布局文件,并且实例 ...
- windows下R语言在终端的运行
在windows下可以有多种方式来运行R,R导论的这些章节给出一些详细的指导. 通常在环境变量离包含R的安装目录类似于R\R-3.1.2\bin\x64的情况下,就可以在CMD下运行R程序了 注意我这 ...
- 通信原理实践(六)——基带传输
一.基带传输引入 1.从数字带通传输说起 以上系统可以等价为: 这里"等价"的假设条件是 •信号通过滤波器不失真 •不存在码间串扰 意义:可以通过评估基带传输系统来获得数字带通传输 ...
- 求余VS求模--C语言中表述
之前看帖子,发现许多时候基本上大家都把求模和求余混为一谈了.但实际上二者的概念是有区别的 1. 求余 在C语言中,求余对应的操作符是%,且a%b求余的最后结果总是与a符号相同,最后的数值为|a|% ...
- winmail服务器启动失败 无法启动
1.解决句柄问题:打开命令行:开始 -> 运行-> 输入 cmd -> 确定.切换命令目录至winmail的服务目录,我的是:E:\htdocs\Winmail\server\> ...