2019.01.24 NOIP训练 旅行(轮廓线dp)
传送门
题意简述:
给一个n∗mn*mn∗m的有障碍的网格图,问你从左上角走到左下角并覆盖所有可行格子的路径条数。
思路:
路径不是很好算。
将图改造一下,在最前面添两列,第一列全部能通过,第二列只有最上面的和最下面的可以通过,就转化成了求回路方案数。
代码:
#include<bits/stdc++.h>
#define ri register int
#define change (f[cur].insert(stat,sum))
using namespace std;
typedef long long ll;
const int mod=2e6+7;
int n,m,mp[20][20],zx,zy;
ll ans=0;
bool cur;
char s[20];
struct Statement{
ll sum[mod];
int sta[mod],idx[mod],tot;
inline void clear(){tot=0,memset(idx,-1,sizeof(idx));}
inline void insert(int stat,ll sums){
int pos=stat%mod;
if(!pos)++pos;
while(~idx[pos]&&sta[idx[pos]]!=stat)pos=pos==mod-1?1:pos+1;
if(~idx[pos])sum[idx[pos]]+=sums;
else sum[idx[pos]=++tot]=sums,sta[tot]=stat;
}
}f[2];
inline int getbit(int x,int p){return (x>>((p-1)<<1))&3;}
inline void update(int&x,int p,int v){x^=(getbit(x,p)^v)<<((p-1)<<1);}
inline int findr(int stat,int p){
for(ri i=p+1,cnt=1,bit;i<=m+1;++i){
bit=getbit(stat,i);
if(bit==1)++cnt;
if(bit==2)--cnt;
if(!cnt)return i;
}
}
inline int findl(int stat,int p){
for(ri i=p-1,cnt=-1,bit;i;--i){
bit=getbit(stat,i);
if(bit==1)++cnt;
if(bit==2)--cnt;
if(!cnt)return i;
}
}
inline void solve(){
f[cur=0].clear(),f[cur].insert(0,1);
for(ri i=1;i<=n;++i){
for(ri j=1;j<=m;++j){
f[cur^=1].clear();
ll sum;
for(ri stat,p,q,tt=1;tt<=f[cur^1].tot;++tt){
stat=f[cur^1].sta[tt],sum=f[cur^1].sum[tt];
p=getbit(stat,j),q=getbit(stat,j+1);
if(!mp[i][j]){if(!(p+q))change;continue;}
if(!(p+q)){if(mp[i+1][j]&&mp[i][j+1])update(stat,j,1),update(stat,j+1,2),change;continue;}
if((p>0)^(q>0)){
if(mp[i+(p>0)][j+(q>0)])change;
if(mp[i+(q>0)][j+(p>0)])update(stat,j,q),update(stat,j+1,p),change;
continue;
}
if(p==1&&q==2){if(i==zx&&j==zy)ans+=sum;continue;}
update(stat,j,0),update(stat,j+1,0);
if(p==2&&q==1){change;continue;}
if(p==1&&q==1){update(stat,findr(stat,j+1),1),change;continue;}
if(p==2&&q==2){update(stat,findl(stat,j),2),change;continue;}
}
}
for(ri j=1;j<=f[cur].tot;++j)f[cur].sta[j]<<=2;
}
}
int main(){
memset(mp,0,sizeof(mp)),scanf("%d%d",&n,&m),m+=2;
if(n==1)return puts("1"),0;
for(ri i=1;i<=n;++i)mp[i][1]=1;
mp[1][2]=mp[n][2]=1;
for(ri i=1;i<=n;++i){
scanf("%s",s+1);
for(ri j=3;j<=m;++j){
mp[i][j]=1-(s[j-2]-'0');
if(mp[i][j])zx=i,zy=j;
}
}
solve(),cout<<ans;
return 0;
}
2019.01.24 NOIP训练 旅行(轮廓线dp)的更多相关文章
- 2019.01.24 bzoj3125: CITY(轮廓线dp)
传送门 题意简述:给一个n∗mn*mn∗m的网格图,有的格子不能走,有的格子只能竖着走,有的格子只能横着走,问用一条回路覆盖所有能走的格子的方案数. 思路: 就是简单的轮廓线dpdpdp加了一点限制而 ...
- 2019.01.24 bzoj2310: ParkII(轮廓线dp)
传送门 题意简述:给一个m*n的矩阵,每个格子有权值V(i,j) (可能为负数),要求找一条路径,使得每个点最多经过一次且点权值之和最大. 思路:我们将求回路时的状态定义改进一下. 现在由于求的是路径 ...
- 2019.01.23 hdu3377 Plan(轮廓线dp)
传送门 题意简述:给一个n*m的带权矩阵,求从左上角走到右下角的最大分数,每个格子只能经过最多一次,n,m≤9n,m\le9n,m≤9. 思路: 考虑轮廓线dpdpdp,但这道题并没有出现回路的限制因 ...
- 2019.01.23 hdu1964 Pipes(轮廓线dp)
传送门 题意简述:给一个没有障碍的网格图,任意两个格子连通需要花费一定代价,现在求一条覆盖所有格子的哈密顿回路的总权值的最小值. 思路: 跟这道题一毛一样,除了把求和变成求最小值以外. 代码: #in ...
- 2019.01.21 NOIP训练 可持久化序列【模板】(可持久化treap)
传送门 题意简述:支持在把某个数插入到某版本的第k个位置,删除某版本第k个数,询问第k个数. 思路:用可持久化treaptreaptreap维护区间第kkk个位置的数是啥就可以了. 代码
- 2019.01.21 NOIP训练 ak树(点分治)
传送门 题意简述:给一棵带权树,问在上面随机选两个点距离是4的倍数的概率. 思路: 由于总方案数为定值n2n^2n2,所以只用求总方案数. 这个跟聪聪可可差不多,可以用类似树形dpdpdp的方法边点分 ...
- 2019.01.02 NOIP训练 三七二十一(生成函数)
传送门 生成函数基础题. 题意简述:求由1,3,5,7,9这5个数字组成的n位数个数,要求其中3和7出现的次数都要是偶数. 考虑对于每个数字构造生成函数. 对于1,5,9:∑nxnn!=ex\sum_ ...
- 2019年9月训练(贰)区间DP (luogu 4290)
区间DP luogu 4290 明显的区间DP. 定义 dp[l][r][k]/*表示区间[l,r]能否凑成k(W,I,N,G)字符*/mp['W']=1;mp['I']=2;mp['N']=3;mp ...
- 2019年9月训练(壹)数位DP (HDU 2089)
开学之后完全没时间写博客.... HDU 2089 不要62(vjudge) 数位DP 思路: 题目给出区间[n,m] ,找出不含4或62的数的个数 用一个简单的差分:先求0~m+1的个数,再减去0~ ...
随机推荐
- hdu 5154 拓扑排序
例题:hdu 5154 链接 http://acm.hdu.edu.cn/showproblem.php?pid=5154 题目意思是第一行先给出n和m表示有n件事,m个关系,接下来输入m行,每行有 ...
- Android 基础 (四大组件,五大存储,六大布局)
Android四大组件: 参考:https://blog.csdn.net/shenggaofei/article/details/52450668 Android四大组件分别为activity.se ...
- Genymotion 模拟器上网出现 net::ERR_NAME_NOT_RESOLVED
Genymotion 模拟器在公司网络安装的,然后启动能正常上网,把笔记本带回家,网络变化了,再使用模拟器 上网显示: (net::ERR_NAME_NOT_RESOLVED) 各种百度,最后用如下方 ...
- 微信小程序开发小技巧——单击事件传参、动态修改样式、轮播样式修改等
一. 脚本部分: 1. 表达式无效的处理: 如果你发现自己编写的表达式无效或者数据不展示,那么请先检查你的表达式是否有添加{{}},小程序中全部都要添加的,只要是在模板中调用js中的数据 2. 获取元 ...
- freetype教程网址
http://freetype.sourceforge.net/freetype2/docs/reference/ft2-system_interface.html#FT_Stream ht ...
- 使用SqlBulkCopy批量插入数据,测试20万条用时5秒
using System;using System.Collections.Generic;using System.Linq;using System.Text; using System.Data ...
- Js学习(2)数据类型
Js共有六种数据类型(ES6又增加了第七种Symbol类型的值): 原始类型:数值,字符串,布尔值 合成类型:对象(object):各种值组成的集合 其他undefined,null 对象又可以分成三 ...
- setTimeout设置为0的意义
今天再看 Promise 代码时,有个地方用到了setTimeOut函数,但是第2个参数设为0,顿时懵逼了,这是啥意思? function resolve(newValue) { value = ne ...
- Java使用默认浏览器打开指定URL的方法(二种方法)
直接看代码:方法一: 复制代码 代码如下: Runtime.getRuntime().exec("rundll32 url.dll,FileProtocolHandler http://ww ...
- 八皇后问题(dfs)
#include <iostream> #include <stdio.h> using namespace std; ; ], b[], c[], vis[][]; //a, ...