P3170-[CQOI2015]标识设计【插头dp】

正题

题目链接:https://www.luogu.com.cn/problem/P3170


题目大意

给出n∗mn*mnm的网格上有一些障碍,要求用三个LLL形(高宽随意,不能退化成线段/点)覆盖格子且LLL形之间不能重叠。

求覆盖方案(每个LLL形相同)

2≤n,m≤302\leq n,m\leq 302n,m30


解题思路

一道比模板要简单的插头dpdpdp?(当然我依旧不会)

先是考虑插头的状态,每个LLL形的话,一个还没有涂完的LLL形可能是右插头或者下插头,因为只有三个所以最多只会有333个下插头,这样的状态数是Cm3C_m^3Cm3的,在500050005000以内。

把这些状态压缩起来,然后设fx,y,s,k,0/1f_{x,y,s,k,0/1}fx,y,s,k,0/1表示现在dpdpdp到格子(x,y)(x,y)(x,y),目前下插头状态为sss,已经插入了kkkLLL形(作为下插头),目前有没有右插头。

转移的话就很简单了,如果下一个格子有障碍那它上面就不能有插头,如果这个格子上面有插头就分为结束这个下插头变为一个右插头或者不结束。
如果这个格子有右插头那么就不能有上插头。
没有这些限制就能够开一个下插头。

需要注意到行尾的时候可能会还有右插头,在最右边加一列障碍就好了。
时间复杂度是O(nmCm3)O(nmC_{m}^3)O(nmCm3)


code

#include<cstdio>
#include<cstring>
#include<algorithm>
#define ll long long
using namespace std;
const ll N=32,M=5100;
ll n,m,cnt,f[N][M][4][2];
ll id[N][N][N],pi[M],pj[M],pk[M];
bool v[N][N];char s[N];
void init(){for(ll i=0;i<=m;i++)for(ll j=i?(i+1):0;j<=m;j++)for(ll k=j?(j+1):0;k<=m;k++){id[i][j][k]=++cnt;pi[cnt]=i;pj[cnt]=j;pk[cnt]=k;}ll p[3];for(ll i=0;i<=m;i++)for(ll j=0;j<=m;j++)for(ll k=0;k<=m;k++){p[0]=i;p[1]=j;p[2]=k;sort(p,p+3);id[i][j][k]=id[p[0]][p[1]][p[2]];}return;
}
signed main()
{scanf("%lld%lld",&n,&m);for(ll i=1;i<=n;i++){scanf("%s",s+1);for(ll j=1;j<=m;j++)if(s[j]=='#')v[i][j]=1;}m++;for(ll i=1;i<=n;i++)v[i][m]=1;ll g=0;f[0][1][0][0]=1;init();for(ll p=1;p<=n*m;p++){ll x=(p-1)/m+1,y=(p-1)%m+1;g^=1;memset(f[g],0,sizeof(f[g]));for(ll s=1;s<=cnt;s++){ll a=pi[s],b=pj[s],c=pk[s];for(ll k=0;k<=3;k++){if(f[!g][s][k][0]){if(!v[x][y]){f[g][s][k][0]+=f[!g][s][k][0];if(y==a)f[g][id[0][b][c]][k][1]+=f[!g][s][k][0];else if(y==b)f[g][id[a][0][c]][k][1]+=f[!g][s][k][0];else if(y==c)f[g][id[a][b][0]][k][1]+=f[!g][s][k][0];else if(k<3) f[g][id[y][b][c]][k+1][0]+=f[!g][s][k][0];}else if(y!=a&&y!=b&&y!=c)f[g][s][k][0]+=f[!g][s][k][0];}if(f[!g][s][k][1]&&!v[x][y]&&y!=a&&y!=b&&y!=c){f[g][s][k][1]+=f[!g][s][k][1];f[g][s][k][0]+=f[!g][s][k][1];}}}}printf("%lld\n",f[g][1][3][0]);return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/319240.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【活动(广州)】MonkeyFest2018 微软最有价值专家讲座

MonkeyFest2018微软最有价值专家讲座Monkey Fest 是一个一年一度由全球Microsoft Xamarin跨平台开发者发起的全球性社区活动&#xff0c;主要是推广在云、人工智能、大数据、移动开发等技术。本次活动同时在新加坡&#xff0c;美国&#xff0c;日本&#xff0c;加拿大&#xff…

【数学】Natasha, Sasha and the Prefix Sums(CF1204E)

正题 luogu CF1204E 题目大意 给出序列a&#xff0c;由n个1和m个-1组成&#xff0c;设 f 为最大前缀和和0的最大值&#xff0c;问全排列的 f 之和 解题思路 可以问题转换到平面图上&#xff0c;把1看作往上走&#xff0c;-1看作往下走 那么问题就变成了求 (0,0) 到 (nm,n-m…

codeforces1454 F. Array Partition

这周忙死&#xff0c;一直没机会吧补一下题&#xff0c;周二晚上打的div3&#xff0c;过了A~E&#xff0c;F就看了下题目就没时间了&#xff0c;无聊的时候想应该会用到ST表&#xff0c;然后想要维护指针&#xff0c;后来写的时候发现维护不了&#xff0c;然后就歇菜了。。。 …

2020牛客国庆集训派对day4 Arithmetic Progressions

Arithmetic Progressions 链接&#xff1a;https://ac.nowcoder.com/acm/contest/7831/B 来源&#xff1a;牛客网 题目描述 An arithmetic progression is a sequence of numbers a1, a2, ..., ak where the difference of consecutive members ai1−ai is a constant (1 ≤ …

P4457-[BJOI2018]治疗之雨【期望dp,高斯消元】

正题 题目链接:https://www.luogu.com.cn/problem/P4457 题目大意 开始一个人最大生命值为nnn&#xff0c;剩余hphphp点生命&#xff0c;然后每个时刻如果生命值没有满那么有1m1\frac{1}{m1}m11​的概率回复一点生命&#xff0c;然后敌人攻击kkk次&#xff0c;每次有1m1\frac…

互联网公司为什么普遍996而不是666

根据skinshoe wu的遭遇&#xff0c;解释一下互联网行业的12小时工作制以及996。题目说的有点绝对&#xff0c;这里先澄清一下&#xff1a;有的公司是10106&#xff0c;9106&#xff0c;10126&#xff0c;995&#xff0c;甚至955&#xff0c;007的都有&#xff0c;我只说大多数&…

【DP】【四边形不等式】邮局(P4767)

正题 P4767 题目大意 给出坐标轴上的n个点&#xff0c;让你选择m个点作为特殊点&#xff0c;使所有点到最近特殊点的距离之和最小 解题思路 考虑对于一个区间选择一个特殊点的最小代价&#xff0c;可以把所有点到当前点的路径分割开来&#xff0c;即每段距离走的次数为1,2,3…

IdentityServer4之JWT签名(RSA加密证书)及验签

一、前言在IdentityServer4中有两种令牌&#xff0c;一个是JWT和Reference Token&#xff0c;在IDS4中默认用的是JWT&#xff0c;那么这两者有什么区别呢&#xff1f;二、JWT与Reference Token的区别1、JWT(不可撤回)  JWT是一个非常轻巧的规范&#xff0c;一般被用来在身份提…

2020牛客国庆集训派对day4 What Goes Up Must Come Down

What Goes Up Must Come Down 题意&#xff1a; 我们规定一个序列合理&#xff1a;当一个序列左部分是非降序列&#xff0c;右部分是非升序列&#xff08;左右部分可为0&#xff0c;也就是整体可以为非降序列&#xff0c;非升序列&#xff09; 题解&#xff1a; 树状数组来…

codeforces1451 E. Bitwise Queries(位运算妙用)

E1. Bitwise Queries (Easy Version) ab(a&b)(a∣b)ab(a\&b)(a|b)ab(a&b)(a∣b) 根据上述式子用333次$&和333次∣|∣操作求出a1a2,a2a3,a1a3a_1a_2,a_2a_3,a_1a_3a1​a2​,a2​a3​,a1​a3​由此得出a1,a2,a3a_1,a_2,a_3a1​,a2​,a3​ 根据a1⊕aixa_1\oplus a…

P4240-毒瘤之神的考验【莫比乌斯反演,平衡规划】

正题 题目链接:https://www.luogu.com.cn/problem/P4240 题目大意 QQQ组数据给出n,mn,mn,m求 ∑i1n∑j1mφ(ij)\sum_{i1}^n\sum_{j1}^m\varphi(i\times j)i1∑n​j1∑m​φ(ij) 1≤Q≤104,1≤n,m≤1051\leq Q\leq 10^4,1\leq n,m\leq 10^51≤Q≤104,1≤n,m≤105 解题思路 首先…

【最小生成树】水箱(P5952)

正题 P5952 题目大意 有一个n*m的网格&#xff0c;每个网格之间有一个板&#xff0c;给出每个板的高度&#xff08;边界有一个高度为 ∞\infty∞ 的墙&#xff09;&#xff0c;在每个网格中注水&#xff08;必须是非负整数&#xff09;&#xff0c;使得两个高度不等且相邻的网…

2020牛客国庆集训派对day4 Jokewithpermutation

Jokewithpermutation 题目描述 Joey had saved a permutation of integers from 1 to n in a text file. All the numbers were written as decimal numbers without leading spaces. Then Joe made a practical joke on her: he removed all the spaces in the file. Help Jo…

.NET Core使用IO合并技巧轻松实现千万级消息推送

之前讲述过多路复用实现单服百万级别RPS吞吐,但在文中有一点是没有说的就是消息IO合并&#xff0c;如果缺少了消息IO合并即使怎样多路复用也很难达到百万级别的请求响毕竟所有应用层面的网络IO读写都是非常损耗性能的&#xff08;需要硬件配置很高的服务器&#xff09;。这一章…

codeforces1457 C. Bouncing Ball

写这个题写了1h&#xff0c;赛后无意看见jly神的代码只能膜拜%%% C. Bouncing Ball 预处理从1→k1\to k1→k开始跳需要添加多少个平台&#xff0c;预处从k1→nk1\to nk1→n这些不难发现由于每次跳k格&#xff0c;只需要利用前缀和思想和前面预处理的结果即可做差求出。 然后枚…

P4491-[HAOI2018]染色【二项式反演,NTT】

正题 题目链接:https://www.luogu.com.cn/problem/P4491 题目大意 给nnn个物品染上mmm种颜色&#xff0c;若恰好有kkk个颜色的物品个数为SSS那么就会产生WkW_kWk​的贡献。求所有染色方案的贡献和 1≤n≤107,1≤m≤105,1≤S≤1501\leq n\leq 10^7,1\leq m\leq 10^5,1\leq S\l…

【传递闭包】【倍增】幸福路径(P4308)

正题 P4308 题目大意 给一个图&#xff0c;每个点有一个权值 axa_xax​&#xff0c;当你经过一条边时体力p\times pp&#xff08;体力初始为1&#xff09;&#xff0c;每到一个点造成的贡献为体力ax\times a_xax​&#xff0c;问最大贡献&#xff08;路径可能是无限长的&…

天气情况图像分类练习赛 第三阶段(赛中感)

第三阶段也是实战阶段&#xff0c;不同于前两个阶段的填空而是实打实的预测分析 题目会给出8000张照片数据&#xff0c;其中6000作为训练集而另外2000张作位测试集&#xff0c;通过对6000张的训练来预测2000的结果&#xff0c;并将结果输出到csv文件中&#xff0c;提交检验成功…

一码阻塞,万码等待:ASP.NET Core 同步方法调用异步方法“死锁”的真相

在我们 2015 年开始的从 .NET Framework 向 .NET Core 迁移的工程中&#xff0c;遇到的最大的坑就是标题中所说的——同步方法中调用异步方法发生”死锁”。虽然在 .NET Framework 时代就知道不能在同步方法中调用异步方法&#xff0c;但我们却明知路有坑&#xff0c;偏向此路行…

codeforces1456 D. XOR-gun

D. XOR-gun 大佬题解 当n比较大的时候&#xff0c;一定有连续相同的3个数最高位都是1&#xff0c;只需要将这三个数其中两个异或一次即可满足题意只需要操作1次。 当n比较小时可以直接暴力&#xff0c;不难发现异或操作要么是一段区间异或然后与区间端点相邻的比较O(n2)O(n^2…