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

#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. oracle基础操作(1)

    以前只是简单用程序操作数据,现在才发现自己没有系统的学习过,所以想在这里记录一下自己在数据库方面遇到的问题,会参考查询网络上一些资料,现在看的是韩顺平oracle视频的笔记: 一.关于oracle系统 ...

  2. iOS9新特性之新添加的关键字

    iOS9 新出的关键字:用来修饰属性,或者方法的参数,返回值 好处:1.迎合swift 2.提高我们开发人员开发规范,减少程序员之间的交流 注意:iOS9新出的的关键字nonnull,nullable ...

  3. PostgreSQL与MySQL比較

    特性 MySQL PostgreSQL 实例 通过执行 MySQL 命令(mysqld)启动实例. 一个实例能够管理一个或多个数据库.一台server能够执行多个 mysqld 实例.一个实例管理器能 ...

  4. c# vs2010 连接access数据库

    第一次在博客园写博文,由于文采不怎么好,即使是自己很熟悉的东西,写起来也会感觉到不知从何讲起,我想写的多了就好了. 这篇文章主要是介绍怎么用c# 语言 vs2010连接access数据库的,连接字符串 ...

  5. tomcat servlet JSP common gateway interface 公共网关接口

    Tomcat主要充当servlet/JSP容器,不过它却有大量的功能可以与传统的Web服务器相媲美,对公共网关接口(Common Gateway Interface)的支持就是其中之一. 传统的Web ...

  6. wireshark 学习 1

    wireshark 调试WiFi 安装之后的启动脚步. #!/bin/bash iw dev mon0 del iw dev wlp3s0 interface add mon0 type monito ...

  7. Break、Continue、Return区别

    1)break     直接跳出当前的循环,从当前循环外面开始执行,忽略循环体中任何其他语句和循环条件测试.他只能跳出一层循环,如果你的循环是嵌套循环,那么你需要按照你嵌套的层次,逐步使用break来 ...

  8. Python序列——序列操作

    Python中的序列包括,字符串.列表.元组.本文介绍序列的通用操作. 1. 切片中的None >>> s = 'abcdefg' >>> for i in ran ...

  9. CSS3学习笔记(4)—上下滑动展开的按钮

    最近写了一个动画,下面来看看我以前写的一个上下滑动展开的按钮效果: 这类的效果经常会在一些网站页面下载按钮处看到,当你鼠标悬浮在下载按钮时,会提醒你是否已注册,或者点击登录什么的小提示~~~~~ 一. ...

  10. Codeforces Round #295 (Div. 2)---B. Two Buttons( bfs步数搜索记忆 )

    B. Two Buttons time limit per test : 2 seconds memory limit per test :256 megabytes input :standard ...