Another Rock-Paper-Scissors Problem

题目连接:

http://codeforces.com/gym/100015/attachments

Description

Sonny uses a very peculiar pattern when it comes to playing rock-paper-scissors. He likes to vary his moves

so that his opponent can’t beat him with his own strategy.

Sonny will play rock (R) on his first game, followed by paper (P) and scissors (S) for his second and

third games, respectively. But what if someone else is using the same strategy? To thwart those opponents,

he’ll then play paper to beat rock, scissors to beat paper, and rock to beat scissors, in that order, for his 4th

through 6th games. After that, he’ll play scissors, rock, and paper for games 7–9 to beat anyone copying

his last set of moves. Now we’re back to the original order—rock, paper, scissors—but instead of being

predictable and using the same moves, do you know what would be better? You guessed it! Sonny then

plays the sequence of moves that would beat anyone trying to copy his whole strategy from his first move,

and on it goes...

To recap, in symbolic form, Sonny’s rock-paper-scissors moves look like this:

RPSPSRSRPPSRSRPRPSSRPRPSPSRPSRSRPRPSSRPRPSPSRRPSPSRSRP ...

The spaces are present only to help show Sonny’s playing pattern and do not alter what move he’ll play on

a certain game.

Naturally, your job is to beat Sonny at his own game! If you know the number of the game that you’ll

be playing against Sonny, can you figure out what move you would need to play in order to beat him?

Input

Each line of the input contains a single integer N,1 ! N ! 1012, the number of the game you’ll be playing

against Sonny. An integer N = 1 indicates it would be Sonny’s first game, N = 7 indicates it would be the

7th game, and so forth. The input terminates with a line with N = 0. For example:

1

7

33

0

Warning: N may be large enough to overflow a 32-bit integer, so be sure to use a larger data type (i.e.

long in Java or long long in C/C++) in your program.

Output

For each test case, output a single line which contains the letter corresponding to the move you would need

to play to beat Sonny on that game. For example, the correct output for the sample input above would be:

P

R

S

Sample Input

1

7

33

0

Sample Output

P

R

S

Hint

题意

剪刀石头布

初始串,RPS

每次操作如下:设现在的串为S

1、将之前的串全部击败,得到S'

2、将S'打败,然后得到S''

然后给你第i位,然后输出打败第i位的策略

题解:

找找规律之后会发现,这个串类似于3进制一样的

比如说23,他是23->14->5->2这样过来的

然后我们只用算他是从哪儿过来的,迭代了几次就好了

代码

#include<bits/stdc++.h>
using namespace std; const long long limit = 1000000000050LL;
vector<long long> three;
string solve(long long n,long long step)
{
if(n==1)
{
if(step%3==0)
return "P";
else if(step%3==1)
return "S";
else
return "R";
}
if(n==2)
{
if(step%3==0)
return "S";
else if(step%3==1)
return "R";
else
return "P";
}
if(n==3)
{
if(step%3==0)
return "R";
else if(step%3==1)
return "P";
else return "S";
}
}
int main()
{
long long k = 3;
for(int i=0;;i++)
{
three.push_back(k);
k*=3;
if(k>limit)
break;
}
long long n;
while(cin>>n)
{
if(n==0)break;
int step = 0;
while(n>3)
{
n-=*--lower_bound(three.begin(),three.end(),n);
step++;
}
cout<<solve(n,step)<<endl;
}
}

Codeforces Gym 100015A Another Rock-Paper-Scissors Problem 找规律的更多相关文章

  1. Gym 101194A / UVALive 7897 - Number Theory Problem - [找规律水题][2016 EC-Final Problem A]

    题目链接: http://codeforces.com/gym/101194/attachments https://icpcarchive.ecs.baylor.edu/index.php?opti ...

  2. 2018 ACM-ICPC 中国大学生程序设计竞赛线上赛 H题 Rock Paper Scissors Lizard Spock.(FFT字符串匹配)

    2018 ACM-ICPC 中国大学生程序设计竞赛线上赛:https://www.jisuanke.com/contest/1227 题目链接:https://nanti.jisuanke.com/t ...

  3. Gym - 101667H - Rock Paper Scissors FFT 求区间相同个数

    Gym - 101667H:https://vjudge.net/problem/Gym-101667H 参考:https://blog.csdn.net/weixin_37517391/articl ...

  4. Codeforces D. Little Elephant and Interval(思维找规律数位dp)

    题目描述: Little Elephant and Interval time limit per test 2 seconds memory limit per test 256 megabytes ...

  5. FFT(Rock Paper Scissors Gym - 101667H)

    题目链接:https://vjudge.net/problem/Gym-101667H 题目大意:首先给你两个字符串,R代表石头,P代表布,S代表剪刀,第一个字符串代表第一个人每一次出的类型,第二个字 ...

  6. SDUT 3568 Rock Paper Scissors 状压统计

    就是改成把一个字符串改成三进制状压,然后分成前5位,后5位统计, 然后直接统计 f[i][j][k]代表,后5局状压为k的,前5局比和j状态比输了5局的有多少个人 复杂度是O(T*30000*25*m ...

  7. Gym101667 H. Rock Paper Scissors

    将第二个字符串改成能赢对方时对方的字符并倒序后,字符串匹配就是卷积的过程. 那么就枚举字符做三次卷积即可. #include <bits/stdc++.h> struct Complex ...

  8. 【题解】CF1426E Rock, Paper, Scissors

    题目戳我 \(\text{Solution:}\) 考虑第二问,赢的局数最小,即输和平的局数最多. 考虑网络流,\(1,2,3\)表示\(Alice\)选择的三种可能性,\(4,5,6\)同理. 它们 ...

  9. 题解 CF1426E - Rock, Paper, Scissors

    一眼题. 第一问很简单吧,就是每个 \(\tt Alice\) 能赢的都尽量让他赢. 第二问很简单吧,就是让 \(\tt Alice\) 输的或平局的尽量多,于是跑个网络最大流.\(1 - 3\) 的 ...

随机推荐

  1. [整] Android Fragment 生命周期图

    1. onAttach ------called once the fragment is associated with its activity 2. onCreate-------called ...

  2. Golang官方图片库

    Golang 的图片出来通过提供操作每一个像素点设置颜色(http://www.cnblogs.com/ghj1976/p/3441536.html) 和 提供通过可选蒙版图片重叠操作 (http:/ ...

  3. 第二个UI脚本--Python+selenium之unittest+HTMLtestRunner及python的继承

    前面有一篇对于常见元素的识别和操作的python自动化脚本,这一篇就接着聊下python的类继承,已经它的第三款unittest框架,和报告收集包HTMLtestRunner的应用. 还是直接上代码吧 ...

  4. ajax连接池和XMLHttpRequest

    连接池 我们公司在路由和交换机web界面和后端交互全部采用的是自己封装的ajax组件完成的,组件有点老了,代码风格和其中的某些用法现在看起来都有点不习惯.今天把这个组件的核心部分的ajax连接池记录下 ...

  5. 用ASP.Net写一个发送ICQ信息的程序

    用ASP.Net写一个发送ICQ信息的程序 这里我给大家提供一个很实用的例子,就是在线发送ICQ信息.想一想我们在网页上直接给朋友发送ICQ信息,那是多么美妙的事情啊.呵呵,在吹牛啊,其实ICQ本来就 ...

  6. JNI编程,C++调用Java

    本地代码中使用Java对象 通过使用合适的JNI函数,你可以创建Java对象,get.set 静态(static)和 实例(instance)的域,调用静态(static)和实例(instance)函 ...

  7. 【leetcode】155 - Min Stack

    Design a stack that supports push, pop, top, and retrieving the minimum element in constant time. pu ...

  8. 微信企业支付--遇到不明确结果的err_code:SYSTEMERROR,NOT_FOUND

    前提 项目开发中实现微信提现的功能.使用到了两个接口 企业付款接口:https://api.mch.weixin.qq.com/mmpaymkttransfers/promotion/transfer ...

  9. c# 运行时替换某文件源代码(将XML 转换成 某个枚举并写入源文件)

    var sr = new StreamReader(Server.MapPath("~/WEB-INF/rule.config")); XmlDocument doc = new ...

  10. 60分钟内从零起步驾驭Hive实战学习笔记

    本博文的主要内容是: 1. Hive本质解析 2. Hive安装实战 3. 使用Hive操作搜索引擎数据实战 SparkSQL前身是Shark,Shark强烈依赖于Hive.Spark原来没有做SQL ...