重构一下就过了,不知道之前错在哪里。

#include<bits/stdc++.h>
using namespace std;
typedef unsigned long long ull; const int INF=0x3f3f3f3f; int solve(); int main() {
#ifdef Yinku
freopen("Yinku.in","r",stdin);
#endif // Yinku
solve();
} int dp[6][6][101][1<<11];
//dp[w][h][t][ch] 表示t时间xy处的接到西瓜状态为ch的最小步数 int g[6][6][101];
//g[w][h][t] 表示t时间xy处的西瓜有哪些 int h,w; inline void update(int x,int y,int t,int ost,int nst) {
if(g[x][y][t+1]&(1<<0))
return;
if(x>1)
dp[x][y][t+1][nst]=min(dp[x][y][t+1][nst],dp[x-1][y][t][ost]+1);
if(x<w)
dp[x][y][t+1][nst]=min(dp[x][y][t+1][nst],dp[x+1][y][t][ost]+1);
if(y>1)
dp[x][y][t+1][nst]=min(dp[x][y][t+1][nst],dp[x][y-1][t][ost]+1);
if(y<h)
dp[x][y][t+1][nst]=min(dp[x][y][t+1][nst],dp[x][y+1][t][ost]+1);
return;
} int solve() {
int T,sx,sy;
scanf("%d%d%d%d%d",&h,&w,&T,&sx,&sy);
int n,m;
scanf("%d%d",&n,&m); memset(g,0,sizeof(g)); int id=1;
for(int i=1; i<=n; i++) {
int t1,t2,a;
scanf("%d%d%d",&t1,&t2,&a);
for(int t=t1; t<t2; t++) {
int x,y;
scanf("%d%d",&x,&y);
if(a==1) {
g[x][y][t]|=(1<<id);
} else {
g[x][y][t]|=(1<<0);
}
}
if(a==1)
id++;
} /*for(int t=1; t<=T; t++) {
for(int nx=1; nx<=w; nx++) {
for(int ny=1; ny<=h; ny++) {
cout<<bitset<4>(g[nx][ny][t])<<" ";
}
cout<<endl;
}
cout<<endl;
}*/ if(g[sx][sy][1]&(1<<0)) {
printf("-1\n");
return 0;
} memset(dp,INF,sizeof(dp));
int ch=g[sx][sy][1]; dp[sx][sy][1][ch]=0; for(int t=1; t<T; t++) {
for(int nx=1; nx<=w; nx++) {
for(int ny=1; ny<=h; ny++) {
int nch=g[nx][ny][t+1];
if(nch&(1<<0))
continue;
for(int ch=0; ch<(1<<id); ch++) {
dp[nx][ny][t+1][ch]=min(dp[nx][ny][t+1][ch],dp[nx][ny][t][ch]);
}
}
}
for(int nx=1; nx<=w; nx++) {
for(int ny=1; ny<=h; ny++) {
int nch=g[nx][ny][t+1];
if(nch&(1<<0))
continue;
for(int ch=0; ch<(1<<id); ch++) {
update(nx,ny,t,ch,ch|nch);
}
}
}
} /*for(int t=1; t<=T; t++) {
printf("t=%d\n",t); for(int i=0; i<((1<<id)-1); i++) {
cout<<"i="<<bitset<10>(i)<<endl;
for(int nx=1; nx<=w; nx++) {
for(int ny=1; ny<=h; ny++) {
printf("%2d ",dp[nx][ny][t][i]!=INF?dp[nx][ny][t][i]:-1);
}
printf("\n");
}
cout<<endl;
}
printf("\n");
}*/ int ans=INF;
for(int nx=1; nx<=w; nx++) {
for(int ny=1; ny<=h; ny++) {
if(g[nx][ny][T]&(1<<0))
continue;
else {
ans=min(ans,dp[nx][ny][T][(1<<id)-2]);
}
}
} if(ans==INF)
ans=-1;
printf("%d\n",ans); return 0;
}

洛谷 - P3786 - 萃香抱西瓜 - 状压dp的更多相关文章

  1. [luogu P3786]萃香抱西瓜 [spfa][状态压缩]

    题目背景 伊吹萃香(Ibuki Suika)正在魔法之森漫步,突然,许多西瓜(Suika)从四周飞来,划出了绚丽的轨迹.虽然阵势有点恐怖,但她还是决定抱走一些西瓜. 题目描述 萃香所处的环境被简化为一 ...

  2. 【题解】洛谷P2704 [NOI2001] 炮兵阵地(状压DP)

    洛谷P2704:https://www.luogu.org/problemnew/show/P2704 思路 这道题一开始以为是什么基于状压的高端算法 没想到只是一道加了一行状态判断的状压DP而已 与 ...

  3. 【题解】洛谷P1896 [SCOI2005] 互不侵犯(状压DP)

    洛谷P1896:https://www.luogu.org/problemnew/show/P1896 前言 这是一道状压DP的经典题 原来已经做过了 但是快要NOIP 复习一波 关于一些位运算的知识 ...

  4. 洛谷P1171 售货员的难题【状压DP】

    题目描述 某乡有n个村庄(1 输入格式: 村庄数n和各村之间的路程(均是整数). 输出格式: 最短的路程. 输入样例: 3 0 2 1 1 0 2 2 1 0 输出样例 3 说明 输入解释 3 {村庄 ...

  5. 2018.07.18 洛谷P1171 售货员的难题(状压dp)

    传送门 感觉是一道经典的状压dp,随便写了一发卡了卡常数开了个O(2)" role="presentation" style="position: relati ...

  6. 洛谷P2761 软件补丁问题(状压dp)

    传送门 啊咧……这题不是网络流二十四题么……为啥是个状压dp…… 把每一个漏洞看成一个状态,直接硬上状压dp 然后因为有后效型,得用spfa //minamoto #include<iostre ...

  7. 洛谷$P3226\ [HNOI2012]$集合选数 状压$dp$

    正解:$dp$ 解题报告: 传送门$QwQ$ 考虑列一个横坐标为比值为2的等比数列,纵坐标为比值为3的等比数列的表格.发现每个数要选就等价于它的上下左右不能选. 于是就是个状压$dp$板子了$QwQ$ ...

  8. 洛谷 P2622 关灯问题II【状压DP】

    传送门:https://www.luogu.org/problemnew/show/P2622 题面: 题目描述 现有n盏灯,以及m个按钮.每个按钮可以同时控制这n盏灯--按下了第i个按钮,对于所有的 ...

  9. UOJ #129 / BZOJ 4197 / 洛谷 P2150 - [NOI2015]寿司晚宴 (状压dp+数论+容斥)

    题面传送门 题意: 你有一个集合 \(S={2,3,\dots,n}\) 你要选择两个集合 \(A\) 和 \(B\),满足: \(A \subseteq S\),\(B \subseteq S\), ...

随机推荐

  1. Python 007- python的各种函数

    1.chr().unichr()和ord() chr()函数用一个范围在range(256)内的(就是0-255)整数作参数,返回一个对应的字符. unichr()跟它一样,只不过返回的是Unicod ...

  2. 程序猿的量化交易之路(27)--Cointrader之PriceData价格数据(14)

    转载须注明出处:http://blog.csdn.net/minimicall?viewmode=contents,http://cloudtrade.top/ PriceData:价格数据.价格数据 ...

  3. iOS设备控制打印机输出文本

    本文转载至 http://tec.5lulu.com/detail/108krn1e6e66m8sbd.html 让我们来看看是如何实现的吧,首先要知道打印机的ip地址,然后用socket通过打印机的 ...

  4. 开源流媒体播放器EasyPlayer

    配套开源流媒体服务器EasyDarwin,我们开发了一款开源的流媒体播放器EasyPlayer(现在已经升级合并到开源EasyClient中):同样,EasyPlayer目前只支持RTSP流媒体协议, ...

  5. PostgreSQL Client Authentication Configuration File

    PostgreSQL: Documentation: 10: 16.4. Installation Procedure https://www.postgresql.org/docs/10/stati ...

  6. Django中如何实现数据库路由?

    虽然我们提供了数据库的信息,它知道怎么连接数据库,但问题是我们保存里面有很多模型,它不知道哪个模型存到哪个数据库.这就要求我们自己来指定,也就是我们自己来实现一个数据库路由.一个数据库路由是一个拥有4 ...

  7. Remote Debugging Android Devices

    Remote Debugging Android Devices //在电脑上远程调试安卓设备 By Kayce Basques Technical Writer at Google By Meggi ...

  8. iOS 判定string是不是中文字符

    +(BOOL)IsChinese:(NSString *)str { ; i< [str length];i++) { int a = [str characterAtIndex:i]; if( ...

  9. Java 符号引用 与 直接引用

    在类的加载过程中的解析阶段,Java虚拟机会把类的二进制数据中的符号引用 替换为 直接引用,如Worker类中一个方法: public void gotoWork(){ car.run(); //这段 ...

  10. [noip2014day1-T3]飞扬的小鸟

    Flappy Bird 是一款风靡一时的休闲手机游戏.玩家需要不断控制点击手机屏幕的频率来调节小鸟的飞行高度,让小鸟顺利通过画面右方的管道缝隙.如果小鸟一不小心撞到了水管或者掉在地上的话,便宣告失败. ...