题目传送门

题目大意

不想写了,直接看题面吧。

思路

被这个题搞自闭了,因为读错题目想一个非常恶心的东西想了一场考试,然后就删代码,然后就被骂了。哎。

需要注意的是:我们只能选一次雀头

于是,不难看出一个 \(\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 麻将 加强版的更多相关文章

  1. 51Nod 1158 全是1的最大子矩阵 —— 预处理 + 暴力枚举 or 单调栈

    题目链接:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1158 1158 全是1的最大子矩阵  基准时间限制:1 秒 空 ...

  2. CSU - 1529 Equator —— DP 最大连续和子序列

    题目链接:http://acm.csu.edu.cn/csuoj/problemset/problem?pid=1529 题解: 一个加强版的最大连续和子序列,序列可以从末尾元素转到首元素. 分两种情 ...

  3. bzoj 1860: [Zjoi2006]Mahjong麻将 题解

    [原题] 1860: [Zjoi2006]Mahjong麻将 Time Limit: 1 Sec  Memory Limit: 64 MB Submit: 211  Solved: 122 [Subm ...

  4. 【题解】P3796【模板】AC自动机(加强版)

    [题解]P3796 [模板]AC自动机(加强版) 记录当前\(cnt\)是第几个"星".记录第几个串是对应着第几个星. 这里补充一点对于\(AC\)自动机的理解.可能一直有个问题我 ...

  5. 题解[LuoguP6222]「P6156简单题」加强版

    题解[LuoguP6222]「P6156简单题」加强版 加强版很好地体现了这个题的真正价值.(当然是指卡常 本题解给出了本题更详尽的推倒导和思考过程,思路与 CYJian 的类似,具体式子的个别地方换 ...

  6. 题解 P1120 【小木棍 [数据加强版]】

    题面 乔治有一些同样长的小木棍,他把这些木棍随意砍成几段,直到每段的长都不超过50. 现在,他想把小木棍拼接成原来的样子,但是却忘记了自己开始时有多少根木棍和它们的长度. 给出每段小木棍的长度,编程帮 ...

  7. 洛谷 P2241统计方形(数据加强版) 题解

    题目传送门 说是加强版,其实可以把棋盘那道题的代码粘过来(注意要开long long): #include<bits/stdc++.h> using namespace std; ,c; ...

  8. 【题解】Luogu P5279 [ZJOI2019]麻将

    原题传送门 希望这题不会让你对麻将的热爱消失殆尽 我们珂以统计每种牌出现的次数,不需要统计是第几张牌 判一副牌能不能和,类似这道题 对于这题: 设\(f[i][j][k][0/1]\)表示前\(i\) ...

  9. GERALD07加强版题解

    题目描述: N个点M条边的无向图,询问保留图中编号在[l,r]的边的时候图中的联通块个数. 输入格式: 第一行四个整数N.M.K.type,代表点数.边数.询问数以及询问是否加密. 接下来M行,代表图 ...

随机推荐

  1. 整型:int

    整型:int 整型变量的定义和输出 注意://short<=int<=long<=longlong   代码示例一:   #include<stdio.h> int ma ...

  2. MVC模式职责分工及学习路上的一些感想

    在正文之前想先说说自己coding道路上的一点感想,不得不感慨一下时间过得很快,之前写过一篇关于JavaWeb_MVC模式的一篇博客,转眼之间时间已经过去了两个月,那时候还是一个刚刚接触JavaWeb ...

  3. 使用 baget 搭建私有 nuget 私有服务

    现在几乎所有语言都提供包管理工具,比如 JavaScript 的 npm ,Java 的 Maven ,Dart 的 pub ..Net 程序当然是 NuGet .NuGet 也出现很多年了,奇怪的是 ...

  4. k8s 存活探针(健康检查)

    重启策略 (RestartPolicy ) Always:当容器终止退出后,总是重启容器,默认策略. OnFailure:当容器异常退出(退出状态码非0)时,才重启容器. Never:当容器终止退出, ...

  5. Redis详解(二)——

    https://www.cnblogs.com/yeya/p/14274948.html https://www.cnblogs.com/liang24/tag/redis/

  6. yield表达式 python语法

    可以先看下这篇文章:http://www.cnblogs.com/jiangtu/articles/6662043.html 原篇是转载的:http://www.python-tab.com/html ...

  7. python 常用的文件操作命令

    一.python中对文件.文件夹操作时经常用到的os模块和shutil模块常用方法. 1.得到当前工作目录,即当前Python脚本工作的目录路径: os.getcwd() 2.返回指定目录下的所有文件 ...

  8. spark集群的构建,python环境

    个人笔记,问题较多 符号说明 [] 表示其中内容可以没有 su [root] 获取root权限 vi /etc/sudoers 1.点击I或Insert获得插入权限 2.在root ALL=(ALL) ...

  9. Collections集合工具类和可变参数

    Collections常用的API: public static <T> boolean addAll(Collection<? super T> c, T... elemen ...

  10. 教你用ps如何将图片、文字做出模糊斑驳的作旧效果

    1.对图片的图层执行滤镜-风格化-扩散,选变亮优先. 2.选择画笔工具,在画笔选项里选择喷溅59像素,画笔大小我用的是100px,大家可以根据自己的情况自定义大小,前景设置为黑色. 3.在图章图层上方 ...