第一次听说斯坦纳树这种东西

先dfs预处理出来dis[i][j][k]表示格子(i,j)向k方向转移能到哪,记忆话搜索预处理,注意如果有环的话特判一下

设f[i][j][x][y]表示复合机器人i-j在(x,y)生成需要推得步数,用spfa转移,因为时间比较紧所以优化spfa,把能转移的放进一个队列(准确的来讲是栈)按f排序,spfa转移到的放到另一个,每次取队首小的更新答案

#include<iostream>
#include<cstdio>
#include<cstring>
#include<queue>
using namespace std;
const int N=505,M=600003,dx[]={0,1,0,-1},dy[]={1,0,-1,0};
int n,h,w,f[10][10][N][N],v[N][N][5],ti,s[M+5],va[N*N],top,inf;
bool mk[N][N];
char c[N][N];
struct qwe
{
int x,y;
qwe(int X=0,int Y=0)
{
x=X,y=Y;
}
}dis[N][N][5],q[N*N],p[M+5];
qwe dfs(int x,int y,int k)
{
if(v[x][y][k]==ti)
return qwe(-1,0);
v[x][y][k]=ti;
if(dis[x][y][k].x!=0)
return dis[x][y][k];
int t=k;
if(c[x][y]=='C')
k=(k+1)%4;
if(c[x][y]=='A')
k=(k+3)%4;
int xx=x+dx[k],yy=y+dy[k];
if(xx>w||xx<1||yy>h||yy<1||c[xx][yy]=='x')
return dis[x][y][t]=qwe(x,y);
return dis[x][y][t]=dfs(xx,yy,k);
}
void spfa(int l,int r)
{
memset(s,0,sizeof(s));
memset(mk,0,sizeof(mk));
int mn=inf,mx=-inf;
for(int i=1;i<=top;i++)
{
s[va[i]]++;
if(va[i]<mn)
mn=va[i];
if(va[i]>mx)
mx=va[i];
mk[q[i].x][q[i].y]=1;
}
for(int i=mn+1;i<=mx;i++)
s[i]+=s[i-1];
for(int i=1;i<=top;i++)
p[s[va[i]]--]=q[i];
for(int i=1;i<=top;i++)
q[i]=p[top-i+1];
int ll=0,rr=0;
while(top||ll!=rr)
{
int now=ll%M+1;
qwe u;
if(ll==rr||(top&&f[l][r][q[top].x][q[top].y]<f[l][r][p[now].x][p[now].y]))
u=q[top--];
else
u=p[ll=now];
int x=u.x,y=u.y;
mk[x][y]=0;
for(int i=0;i<4;i++)
{
int tx=dis[x][y][i].x,ty=dis[x][y][i].y;
if(tx!=-1&&f[l][r][x][y]+1<f[l][r][tx][ty])
{
f[l][r][tx][ty]=f[l][r][x][y]+1;
if(!mk[tx][ty])
{
mk[tx][ty]=1;
p[rr=rr%M+1]=qwe(tx,ty);
}
}
}
}
}
int main()
{
scanf("%d%d%d",&n,&h,&w);
for(int i=1;i<=w;i++)
scanf("%s",c[i]+1);
memset(f,127/3,sizeof(f));
inf=f[0][0][0][0];cerr<<inf<<endl;
for(int i=1;i<=w;i++)
for(int j=1;j<=h;j++)
if(c[i][j]!='x')
for(int k=0;k<4;k++)
ti++,dis[i][j][k]=dfs(i,j,k);
for(int i=1;i<=w;i++)
for(int j=1;j<=h;j++)
if(c[i][j]>='0'&&c[i][j]<='9')
f[c[i][j]-48][c[i][j]-48][i][j]=0;
for(int l=1;l<=n;l++)
for(int x=1;x<=n-l+1;x++)
{
int y=x+l-1;top=0;
for(int i=1;i<=w;i++)
for(int j=1;j<=h;j++)
{
for(int k=x;k<y;k++)
if(f[x][y][i][j]>f[x][k][i][j]+f[k+1][y][i][j])
f[x][y][i][j]=f[x][k][i][j]+f[k+1][y][i][j];
if(f[x][y][i][j]!=inf)
{
q[++top]=qwe(i,j);
va[top]=f[x][y][i][j];
}
}
spfa(x,y);
}
int ans=inf;
for(int i=1;i<=w;i++)
for(int j=1;j<=h;j++)
if(f[1][n][i][j]<ans)
ans=f[1][n][i][j];
printf("%d\n",ans==inf?-1:ans);
return 0;
}

bzoj 3205: [Apio2013]机器人【dfs+斯坦纳树+spfa】的更多相关文章

  1. [Bzoj3205][Apio2013]机器人(斯坦纳树)(bfs)

    3205: [Apio2013]机器人 Time Limit: 15 Sec  Memory Limit: 128 MBSubmit: 977  Solved: 230[Submit][Status] ...

  2. BZOJ 3205 [Apio2013]机器人 ——斯坦纳树

    腊鸡题目,实在卡不过去. (改了一下午) 就是裸的斯坦纳树的题目,一方面合并子集,另一方面SPFA迭代求解. 优化了许多地方,甚至基数排序都写了. 还是T到死,不打算改了,就这样吧 #include ...

  3. BZOJ 2595: [Wc2008]游览计划 [DP 状压 斯坦纳树 spfa]【学习笔记】

    传送门 题意:略 论文 <SPFA算法的优化及应用> http://www.cnblogs.com/lazycal/p/bzoj-2595.html 本题的核心就是求斯坦纳树: Stein ...

  4. BZOJ 2595 [Wc2008]游览计划 ——斯坦纳树

    [题目分析] 斯坦纳树=子集DP+SPFA? 用来学习斯坦纳树的模板. 大概就是用二进制来表示树包含的点,然后用跟几点表示树的形态. 更新分为两种,一种是合并两个子集,一种是换根,换根用SPFA迭代即 ...

  5. BZOJ 5180 [Baltic2016]Cities(斯坦纳树)

    斯坦纳树的板子题. 斯坦纳树问题是组合优化问题,与最小生成树相似,是最短网络的一种. 最小生成树是在给定的点集和边中寻求最短网络使所有点连通. 而最小斯坦纳树允许在给定点外增加额外的点,使生成的最短网 ...

  6. bzoj 4006 [JLOI2015]管道连接——斯坦纳树

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4006 除了模板,就是记录 ans[ s ] 表示 s 合法的最小代价.合法即保证 s 里同一 ...

  7. [APIO2013]机器人(斯坦纳树)

    题目描述 VRI(Voltron 机器人学会)的工程师建造了 n 个机器人.任意两个兼容的机 器人站在同一个格子时可以合并为一个复合机器人. 我们把机器人用 1 至 n 编号(n ≤ 9).如果两个机 ...

  8. [APIO2013]机器人[搜索、斯坦纳树]

    题意 题目链接 分析 记 g(d,x,y) 表示从 (x,y) 出发,方向为 d 到达的点,这个可以通过记忆化搜索求出,注意如果转移成环(此时向这个方向走没有意义)要特判. 记 f(l,r,x,y) ...

  9. [BZOJ3205][APIO2013]Robot(斯坦纳树)

    3205: [Apio2013]机器人 Time Limit: 15 Sec  Memory Limit: 128 MBSubmit: 1007  Solved: 240[Submit][Status ...

随机推荐

  1. SQL SERVER 2012 第四章 连接 JOIN の INNER JOIN

    所有JOIN语句的共同点是:将一个记录与另外一个或多个记录匹配,从而生成一个新记录,这个记录是由两个记录的合并列所产生的一个超集. 内部连接: 内部连接语法结构:SELECT <select l ...

  2. poj——3177Redundant Paths

    poj——3177Redundant Paths      洛谷—— P2860 [USACO06JAN]冗余路径Redundant Paths Time Limit: 1000MS   Memory ...

  3. [Poj2096]Collecting Bugs(入门期望dp)

    Collecting Bugs Time Limit: 10000MS   Memory Limit: 64000K Total Submissions: 6237   Accepted: 3065 ...

  4. 【python】urllib2

    urllib2.urlopen(url[, data][, timeout]) 请求url,获得请求数据,url参数可以是个String,也可以是个Request参数 没有data参数时为GET请求, ...

  5. IntelliJ IDEA 使用maven 集成SpringMVC+Hibernate

    准备工作: 安装idea intellij 安装jdk1.8,配好环境变量 安装tomcat 7 准备工作完成之后,就开始创建项目了 创建项目 1.File–>new project–>选 ...

  6. UICollectionView 具体解说学习

    UICollectionView 和UITableView非常像,是APPLE公司在iOS 6后推出的用于处理图片这类UITableView 布局困难的控件,和UITableView 一样,它也有自己 ...

  7. 安装PyQt5和Eric6

    安装官方的指引,安装起来本来是非常简单的,但是我前后折腾了两天,甚至连Eric得源码都去调试都没成功.过程如下: 在PyQt5的官网链接中下载轮子 PyQt5-5.7.1-5.7.1-cp34.cp3 ...

  8. Hadoop DistributedCache使用案例

    背景 公司数据处理具有两个计算框架,单机框架和MR框架.眼下我已经抽象出一套API interface, 供业务计算开发者使用. 并分别在两个计算框架下实现了API的运行调度.应用开发者有时间须要通过 ...

  9. Windows Server 2012 R2 安装.NET Framework 3.5报错

    简单记录一下,Windows Server 2012 R2 安装.NET Framework 3.5报错,下面是解决方法 载入ISO文件Windows Server 2012 R2,而且在安装的过程中 ...

  10. iOS 浅谈MVC设计模式及Controllers之间的传值方式

    1.简述你对MVC的理解? MVC是一种架构设计.它考虑了三种对象:Model(模型对象).View(试图对象).Controller(试图控制器) (1)模型:负责存储.定义.操作数据 (2)视图: ...