题解 P6454 麻将 加强版
题目大意
不想写了,直接看题面吧。
思路
被这个题搞自闭了,因为读错题目想一个非常恶心的东西想了一场考试,然后就删代码,然后就被骂了。哎。
需要注意的是:我们只能选一次雀头
于是,不难看出一个 \(\Theta(n^3)\) 的做法,可以枚举听哪张牌,选哪个雀头,然后我们判断的时候显然我们应该多选刻子,选不下去的时候就从后面的值选出连子,实际操作中直接减就行了。也可以看出来,从后往前贪心也是可以的。
来看 \(\Theta(n^2)\) 做法。不难发现每次听牌的时候贪心前面一部分都是不变的,如果从后往前贪心也是一样。因为我们如果听牌 \(a\),那么只有后面的牌会受到影响。如果我们假设分别贪到 \(l,r\) 就不可以再继续贪了,那么我们的雀头一定在 \([r-1,l]\) 中(可以看出,在合法情况下 \(r<l\))。于是,我们可以考虑 dp,我们设 \(f_{i,0/1}\) 表示从前往后贪心贪到第 \(i\) 个位置,第 \(i+1/i+2\) 需要减去的值是多少,同理,我们可以设 \(g_{i,0/1}\) 表示从后往前的贪心。考虑一个点是否可以被听,可以发现如果设 \(x=a_{i}-f_{i-1,0}-g_{i+2,1},y=a_{i+1}\),那么当 \(x,y\ge 0\) 并且 \(x,y\) 中任一为 \(2\) 另一个为 \(0\) 牌 \(i-1\) 就是可听的。
所以,时间复杂度就降到了 \(\Theta(n^2)\)。
\(\texttt{Code}\)
#include <bits/stdc++.h>
using namespace std;
#define Int register int
#define MAXN 5005
template <typename T> void read (T &x){char c = getchar ();x = 0;int f = 1;while (c < '0' || c > '9') f = (c == '-' ? -1 : 1),c = getchar ();while (c >= '0' && c <= '9') x = x * 10 + c - '0',c = getchar ();x *= f;}
template <typename T,typename ... Args> void read (T &x,Args& ... args){read (x),read (args...);}
template <typename T> void write (T x){if (x < 0) x = -x,putchar ('-');if (x > 9) write (x / 10);putchar (x % 10 + '0');}
template <typename T> void Mx (T &a,T b){a = max (a,b);}
template <typename T> void Mi (T &a,T b){a = min (a,b);}
int n,k,a[MAXN],b[MAXN],dp1[MAXN][2],dp2[MAXN][2];
bool check (){
for (Int i = 1;i <= n;++ i) b[i] = a[i];
int posl = n - 1,posr = 2;//我无论如何怎么选雀头都必须对这两个点产生影响
for (Int i = 1;i <= n - 2;++ i){
b[i] -= dp1[i - 1][0];
if (b[i] < 0){
posl = i;
break;
}b[i] %= 3;
dp1[i][0] = dp1[i - 1][1] + b[i],dp1[i][1] = b[i];
}
for (Int i = 1;i <= n;++ i) b[i] = a[i];
for (Int i = n;i >= 3;-- i){
b[i] -= dp2[i + 1][0];
if (b[i] < 0){
posr = i;
break;
}b[i] %= 3;
dp2[i][0] = dp2[i + 1][1] + b[i],dp2[i][1] = b[i];
}
// cout << posl << " " << posr << endl;
for (Int i = posr - 1;i <= posl;++ i){
int x = a[i] - dp1[i - 1][0] - dp2[i + 2][1],y = a[i + 1] - dp1[i - 1][1] - dp2[i + 2][0];
if (x >= 0 && y >= 0)
if ((x % 3 == 0 && y % 3 == 2) || (x % 3 == 2 && y % 3 == 0))
return 1;
}
for (Int i = 1;i <= n;++ i) if (a[i] & 1) return 0;
return 1;
}
signed main(){
read (n,k);
for (Int i = 1,val;i <= k;++ i) read (val),++ a[val];
vector <int> ans;
for (Int i = 1;i <= n;++ i){
++ a[i];
if (check ()) ans.push_back (i);
-- a[i];
}
write (ans.size()),putchar ('\n');
for (Int v : ans) write (v),putchar (' ');
return 0;
}
题解 P6454 麻将 加强版的更多相关文章
- 51Nod 1158 全是1的最大子矩阵 —— 预处理 + 暴力枚举 or 单调栈
题目链接:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1158 1158 全是1的最大子矩阵 基准时间限制:1 秒 空 ...
- CSU - 1529 Equator —— DP 最大连续和子序列
题目链接:http://acm.csu.edu.cn/csuoj/problemset/problem?pid=1529 题解: 一个加强版的最大连续和子序列,序列可以从末尾元素转到首元素. 分两种情 ...
- bzoj 1860: [Zjoi2006]Mahjong麻将 题解
[原题] 1860: [Zjoi2006]Mahjong麻将 Time Limit: 1 Sec Memory Limit: 64 MB Submit: 211 Solved: 122 [Subm ...
- 【题解】P3796【模板】AC自动机(加强版)
[题解]P3796 [模板]AC自动机(加强版) 记录当前\(cnt\)是第几个"星".记录第几个串是对应着第几个星. 这里补充一点对于\(AC\)自动机的理解.可能一直有个问题我 ...
- 题解[LuoguP6222]「P6156简单题」加强版
题解[LuoguP6222]「P6156简单题」加强版 加强版很好地体现了这个题的真正价值.(当然是指卡常 本题解给出了本题更详尽的推倒导和思考过程,思路与 CYJian 的类似,具体式子的个别地方换 ...
- 题解 P1120 【小木棍 [数据加强版]】
题面 乔治有一些同样长的小木棍,他把这些木棍随意砍成几段,直到每段的长都不超过50. 现在,他想把小木棍拼接成原来的样子,但是却忘记了自己开始时有多少根木棍和它们的长度. 给出每段小木棍的长度,编程帮 ...
- 洛谷 P2241统计方形(数据加强版) 题解
题目传送门 说是加强版,其实可以把棋盘那道题的代码粘过来(注意要开long long): #include<bits/stdc++.h> using namespace std; ,c; ...
- 【题解】Luogu P5279 [ZJOI2019]麻将
原题传送门 希望这题不会让你对麻将的热爱消失殆尽 我们珂以统计每种牌出现的次数,不需要统计是第几张牌 判一副牌能不能和,类似这道题 对于这题: 设\(f[i][j][k][0/1]\)表示前\(i\) ...
- GERALD07加强版题解
题目描述: N个点M条边的无向图,询问保留图中编号在[l,r]的边的时候图中的联通块个数. 输入格式: 第一行四个整数N.M.K.type,代表点数.边数.询问数以及询问是否加密. 接下来M行,代表图 ...
随机推荐
- Centos7.4 安装MySQL 5.7.21 (通用二进制包)
1.下载安装包 MySQL 官方下载地址:https://dev.mysql.com/downloads/mysql/ MySQL 5.7官方安装文档:https://dev.mysql.com/do ...
- JavaScript高级程序设计学习笔记之事件
1.事件流 事件流描述的是从页面中接收事件的顺序. 事件冒泡 IE的事件流叫做事件冒泡(event bubbling),即事件开始时由最具体的元素(文档中嵌套层次最深的那个节点)接收,然后逐级向上传播 ...
- DNS重新绑定攻击
来自微信外挂的安全风险 DNS重新绑定攻击 DDNS 动态域名设置
- MPI集群搭建
高性能计算 ubantu下集群搭建 参考博客:https://blog.csdn.net/u012304016/article/details/52423738(尊重别人的知识产权),一些细节 ...
- github搜索技巧小结
欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...
- Python习题集(十一)
每天一习题,提升Python不是问题!!有更简洁的写法请评论告知我! https://www.cnblogs.com/poloyy/category/1676599.html 题目 如果一个正整数等于 ...
- 学了这么多年C语言,你真的知道全局变量,局部变量,静态变量,本地函数,外部函数是如何区分标识的吗?
动态库内容分析 文章目录 动态库内容分析 1. 动态库编译 1.1 第一个C文件:basic.c 1.2第二个C文件:demo.c 1.3第三个C文件:main.c 2.动态库编译 3.二进制内容分析 ...
- Git:为Git Bash.exe设置默认起始目录的两种方式(start in、~/.bashrc)
在协作开发的过程中,我们经常要进行一些项目的上传拉取操作. 在无数次不厌其烦的打开关闭 Git Bash 后,我实在忍受不了作为一个程序员还要每次都要进行如下的小白操作了 cd /d/my-proje ...
- JAVA反序列化的简单探究
JAVA反序列化的简单探究 本文主要是探究,在反序列化过程中是怎么调用到readObject.readResolve.readExternal方法的问题 新建一个需要被序列化的类ObjectA,写入r ...
- Docker 容器间的单向连接
Docker 容器间的单向连接 前言 a. 本文主要为 Docker的视频教程 笔记. b. 环境为 CentOS 7.0 云服务器 c. 上一篇:Dockerfile 自动制作 Docker 镜像( ...