题目

Input

第一行两个整数N和M,为矩阵的边长。 第二行一个整数D,为豆子的总个数。 第三行包含D个整数V1到VD,分别为每颗豆子的分值。 接着N行有一个N×M的字符矩阵来描述游戏矩阵状态,0表示空格,#表示障碍物。而数字1到9分别表示对应编号的豆子。

Output

仅包含一个整数,为最高可能获得的分值。

Sample Input

3 8
3
30 -100 30
00000000
010203#0
00000000

Sample Output

38

Hint

50%的数据满足1≤D≤3。 100%的数据满足1≤D≤9,1≤N, M≤10,-10000≤Vi≤10000。

分析

首先考虑一下点被包围的情况,在网上看到了一种不错的方法,也就是射线法。也就是从一个点向右做一条射线,如果与路线的交点个数为奇数,则这个点一定被围起来了。下边有几个图加强一下理解:

到这里我们可以看到如果交点奇数个,那么这个点就是被围起来的,反之则没有被围起来。

这个是一种特殊的情况,如果两条相交的边是同向的,那么也有可能包围这个点。于是乎我们就可以将射线向下移动半格。

因为这个转移是存在环的,所以选择spfa

代码

 1 #include <cstdio>
2 #include <cstring>
3 #include <iostream>
4 #include <queue>
5 using namespace std;
6 const int maxn=(1<<9)+3;
7 int f[10][10][maxn],val[maxn];
8 int inq[10][10][maxn],v[10],tr[10][10],dx[]={1,0,-1,0},dy[]={0,1,0,-1};
9 char s[10][10];
10 queue<int> q1,q2,q3;
11 int n,m,K,ans;
12 int main()
13 {
14 scanf("%d%d%d",&n,&m,&K);
15 int i,j,k,S,T,a,b,c,d;
16 for(i=0;i<K;i++)scanf("%d",&v[i]);
17 for(i=1;i<(1<<K);i++){
18 for(j=0;j<K;j++)
19 if((i>>j)&1){
20 val[i]=val[i^(1<<j)]+v[j];
21 break;
22 }
23 }//射线法找围住的点
24 for(i=0;i<n;i++){
25 scanf("%s",s[i]);
26 S=0;
27 for(j=0;j<m;j++){
28 if(s[i][j]>='1'&&s[i][j]<='9') S|=1<<(s[i][j]-'1');
29 tr[i][j]=S;
30 }
31 }//spfa
32 for(i=0;i<n;i++)
33 for(j=0;j<m;j++)
34 if(s[i][j]=='0'){
35 memset(f,0x3f,sizeof(f));
36 f[i][j][0]=0;
37 q1.push(i),q2.push(j),q3.push(0);
38 while(!q1.empty()){
39 a=q1.front(),b=q2.front(),S=q3.front(),inq[a][b][S]=0,q1.pop(),q2.pop(),q3.pop();
40 if(a==i&&b==j){
41 ans=max(ans,val[S]-f[a][b][S]);//用f[a][b][S]表示当前走到(a,b),已经围住的豆豆状态为S的最短路
42 }
43 for(k=0;k<4;k++){
44 c=a+dx[k],d=b+dy[k];
45 if(c<0||c==n||d<0||d==m||s[c][d]!='0') continue;
46 T=S;
47 if(k==0)T^=tr[a][b];
48 if(k==2)T^=tr[c][d];
49 if(f[c][d][T]>f[a][b][S]+1){
50 f[c][d][T]=f[a][b][S]+1;
51 if(!inq[c][d][T]) inq[c][d][T]=1,q1.push(c),q2.push(d),q3.push(T);
52 }
53 }
54 }
55 }
56 printf("%d",ans);
57 return 0;
58 }

(PS:这道题本人还不是理解的特别透彻,只是大致理解了思路和做法,代码的内容还要细细钻研琢磨。)

【状压dp】Bzoj1294 围豆豆的更多相关文章

  1. CDOJ 1402 三角形棋盘上的博弈游戏 状压DP

    三角形棋盘上的博弈游戏 题目连接: http://mozhu.today/#/problem/show/1402 Description 柱爷有天上课无聊,于是和同桌卿学姐一起下一种奇特的棋: 棋盘如 ...

  2. 【[APIO/CTSC2007]动物园】状压DP

    题目测评:https://www.luogu.org/problemnew/show/P3622 题目描述 新建的圆形动物园是亚太地区的骄傲.圆形动物园坐落于太平洋的一个小岛上,包含一大圈围栏,每个围 ...

  3. UVa 1204 Fun Game (状压DP)

    题意:有一些小孩(至少两个)围成一圈,有 n 轮游戏,每一轮从某个小孩开始往左或者往右伟手帕,拿到手帕写上自己的性别(B,G),然后以后相同方向给下一个. 然后在某个小孩结束,给出 n 轮手帕上的序列 ...

  4. BZOJ 1087: [SCOI2005]互不侵犯King [状压DP]

    1087: [SCOI2005]互不侵犯King Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 3336  Solved: 1936[Submit][ ...

  5. nefu1109 游戏争霸赛(状压dp)

    题目链接:http://acm.nefu.edu.cn/JudgeOnline/problemShow.php?problem_id=1109 //我们校赛的一个题,状压dp,还在的人用1表示,被淘汰 ...

  6. poj3311 TSP经典状压dp(Traveling Saleman Problem)

    题目链接:http://poj.org/problem?id=3311 题意:一个人到一些地方送披萨,要求找到一条路径能够遍历每一个城市后返回出发点,并且路径距离最短.最后输出最短距离即可.注意:每一 ...

  7. [NOIP2016]愤怒的小鸟 D2 T3 状压DP

    [NOIP2016]愤怒的小鸟 D2 T3 Description Kiana最近沉迷于一款神奇的游戏无法自拔. 简单来说,这款游戏是在一个平面上进行的. 有一架弹弓位于(0,0)处,每次Kiana可 ...

  8. 【BZOJ2073】[POI2004]PRZ 状压DP

    [BZOJ2073][POI2004]PRZ Description 一只队伍在爬山时碰到了雪崩,他们在逃跑时遇到了一座桥,他们要尽快的过桥. 桥已经很旧了, 所以它不能承受太重的东西. 任何时候队伍 ...

  9. bzoj3380: [Usaco2004 Open]Cave Cows 1 洞穴里的牛之一(spfa+状压DP)

    数据最多14个有宝藏的地方,所以可以想到用状压dp 可以先预处理出每个i到j的路径中最小权值的最大值dis[i][j] 本来想用Floyd写,无奈太弱调不出来..后来改用spfa 然后进行dp,这基本 ...

  10. HDU 1074 Doing Homework (状压dp)

    题意:给你N(<=15)个作业,每个作业有最晚提交时间与需要做的时间,每次只能做一个作业,每个作业超出最晚提交时间一天扣一分 求出扣的最小分数,并输出做作业的顺序.如果有多个最小分数一样的话,则 ...

随机推荐

  1. MyBatis(一) 概述与SQL定制、对象映射

    个人博客网:https://wushaopei.github.io/    (你想要这里多有) 一.MyBatis概述 1.mybatis简介 MyBatis 是支持定制化 SQL.存储过程以及高级映 ...

  2. Java实现 蓝桥杯 算法训练 Anagrams问题

    算法训练 Anagrams问题 时间限制:1.0s 内存限制:512.0MB 问题描述 Anagrams指的是具有如下特性的两个单词:在这两个单词当中,每一个英文字母(不区分大小写)所出现的次数都是相 ...

  3. STL中的string

    string常用函数 1.构造函数 string(const char *s); //用c字符串s初始化 string(int n,char c); //用n个字符c初始化 string类还支持默认构 ...

  4. 1.react的基础

    1.react:专注于UI得一个js库 2.选择使用框架得原因: 写起来简单方便了,但是从稳定性上考虑得话还是原生js要稳定,所以也有很多公司直接使用原生js,但是从开发周期上来说时间会长 之前再写页 ...

  5. Flutter学习笔记(31)--异步更新UI

    如需转载,请注明出处:Flutter学习笔记(31)--异步更新UI 大家都知道,子线程不能操作UI控件,在我们Android的日常开发中,经常会遇到网络请求数据通过线程间通信,将数据发送到UI线程中 ...

  6. CSS sprites的定义及使用

    定义:CSS sprites 其实就是把网页中的一些背景图片整合到一张图片文件中,再利用CSS的“background-image”.“background-repeat”.“background-p ...

  7. SpringBoot 缓存工作原理

    1. 自动配置类:CacheAutoConfiguration 2. 缓存的配置类: org.springframework.boot.autoconfigure.cache.GenericCache ...

  8. 谷歌Chrome成最受欢迎的浏览器 它为啥好用?

    毫无疑问,在搜索引擎领域,谷歌是绝对的主导者.但是,一般人却很容易低估我们受到的“控制”.比如,它的浏览器Chrome. 在不到九年的时间,谷歌Chrome浏览器已经成为全球使用最多的网页浏览器.目前 ...

  9. GridView绑定数据与隐藏指定控件(模板列)

    1.1.    GridView绑定数据 1)       可以配置SqlDataSource数据源,修改select语句生成框架(不想手动绑定) 2)       删除DataSourceID属性和 ...

  10. Java基本数据类型和包装类

    一:八大基本类型 二:基本数据类型及包装类 三:基本类型和包装类的区别 1:定义不同.封装类是对象:基本类型不是. 2:使用方式不同.包装类需要先new初始化,再通过JVM根据具体情况实例化后赋值:基 ...