这道题问的是石头剪刀布的的出题问题

首先不难看出这是个dp题

其次这道题的状态也很好确定,之前输赢与之后无关,确定三个状态:当前位置,当前手势,当前剩余次数,所以对于剪刀,要么出石头+1分用一次机会,要么不用机会然后也不加分

然后dp一下就行了,很简单的一道题

#include <bits/stdc++.h>
#include <bits/extc++.h>
using namespace std;
#define limit (100000 + 5)//防止溢出
#define INF 0x3f3f3f3f
#define inf 0x3f3f3f3f3f
#define lowbit(i) i&(-i)//一步两步
#define EPS 1e-6
#define FASTIO ios::sync_with_stdio(false);cin.tie(0);
#define ff(a) printf("%d\n",a );
#define pi(a,b) pair<a,b>
#define rep(i, a, b) for(ll i = a; i <= b ; ++i)
#define per(i, a, b) for(ll i = b ; i >= a ; --i)
#define MOD 998244353
#define traverse(u) for(int i = head[u]; ~i ; i = edge[i].next)
#define FOPEN freopen("C:\\Users\\tiany\\CLionProjects\\acm_01\\data.txt", "rt", stdin)
#define FOUT freopen("C:\\Users\\tiany\\CLionProjects\\acm_01\\dabiao.txt", "wt", stdout)
#define debug(x) cout<<x<<endl
typedef long long ll;
typedef unsigned long long ull;
inline ll read(){
ll sign = 1, x = 0;char s = getchar();
while(s > '9' || s < '0' ){if(s == '-')sign = -1;s = getchar();}
while(s >= '0' && s <= '9'){x = (x << 3) + (x << 1) + s - '0';s = getchar();}
return x * sign;
}//快读
void write(ll x){
if(x < 0) putchar('-'),x = -x;
if(x / 10) write(x / 10);
putchar(x % 10 + '0');
}
int kase;
int n,k;
int dp[limit][3][22]; int c[limit];
int dfs(int cur, int gest, int tot){
if(dp[cur][gest][tot])return dp[cur][gest][tot];
if(cur > n)return 0;
int ans = dfs(cur + 1, gest, tot);
if(c[cur] == gest)++ans;
if(tot > 0){
int t,p;
if(gest == 0)t = 1, p = 2;
else if(gest == 2)t = 0,p = 1;
else t = 0, p = 2;
ans = max({ans, dfs(cur + 1, t, tot - 1), dfs(cur + 1, p, tot - 1)});
}
return dp[cur][gest][tot] = ans;
}
int main() {
#ifdef LOCAL
FOPEN;
#endif
FASTIO
cin>>n>>k;
rep(i,1,n){
char cc;
cin>>cc;
if(cc == 'H'){
c[i] = 0;
}else if(cc == 'S'){
c[i] = 1;
}else{
c[i] = 2;
}
}
int ans = 0; cout<<max({ans,dfs(1,0,k),dfs(1,1,k),dfs(1,2,k)});;
return 0;
}

最新文章

  1. android输入限制
  2. IOS中block和代理
  3. 在OSX和Windows版本Docker上运行GUI程序
  4. js函数的几个特殊点
  5. 用AsyncTask 来实现下载图片在android开发中
  6. centos install shutter (How to enable Nux Dextop repository on CentOS or RHEL)
  7. ZOJ3471--Most Powerful(状压DP)
  8. QVW中实现日期区间的选择功能!
  9. rspec学习02
  10. eclipse 工具栏修改
  11. windows安装虚拟机(VMware)
  12. 【MIT-6.824】Lab 1: MapReduce
  13. python 如何把小数变成百分数格式
  14. attribute与parameter区别(转)
  15. 在本机搭建mycat 单机环境,使用mariadb 伪集群
  16. JAVASCRIPT开发HTML5游戏--斗地主(网络对战PART4)
  17. XML格式化加载的时候提示Content is not allowed in prolog. Nested exception: Content is not allowed in prolog
  18. java-虚拟机-索引
  19. Http中的身份传递
  20. HIVE- 新建UDF范例

热门文章

  1. 三十二张图告诉你,Jenkins构建Spring Boot 有多简单~
  2. WSL Ubuntu 18.04 LTS + VS Code
  3. C# 全局唯一标识符 (GUID)
  4. Java—多线程
  5. 守护进程详解以及start-stop-daemon命令
  6. 动态导航栏和JavaScript箭头函数
  7. Spark SQL | 目前Spark社区最活跃的组件之一
  8. go-zero 如何扛住流量冲击(二)
  9. 轻松学编曲,论FL钢琴卷帘
  10. 怎么在Word上编辑数学公式?教你一招