[Tjoi2013]循环格

2014年3月18日1,7500

Description

Input

第一行两个整数R,C。表示行和列,接下来R行,每行C个字符LRUD,表示左右上下。

Output

一个整数,表示最少需要修改多少个元素使得给定的循环格完美

Sample Input

3 4
RRRD
URLL
LRRR

Sample Output

2

HINT

1<=R,L<=15

这道题是费用流真的没看出来,每个点只应该有一个出度和一个入度。这一点只要确定了,就可以保证了每个点循环,十分巧妙,然后只要费用流确保每个点如此即可。

 #include<cstdio>
#include<algorithm>
#include<cmath>
#include<iostream>
#include<cstring>
#include<queue>
using namespace std; const int lx[]={,,,-},ly[]={,,-,};
const int INF=1e9+,NN=**+,MM=; int n,m,S,T;
int cnt,head[NN],next[MM],rea[MM],val[MM],cost[MM];
int dis[NN],flag[NN],a[NN][NN],mark[NN][NN];
char s[];
struct Node
{
int e,fa;
void init(){e=fa=-;}
}pre[NN]; void add(int u,int v,int fee,int fare)
{
cnt++;
next[cnt]=head[u];
head[u]=cnt;
rea[cnt]=v;
val[cnt]=fee;
cost[cnt]=fare;
}
void build()
{
int adq=n*m,nx,ny;
for (int i=;i<=n;i++)
for (int j=;j<=m;j++)
for (int k=;k<;k++)
{
nx=i+lx[k],ny=j+ly[k];
if (nx<) nx=n;
if (ny<) ny=m;
if (nx>n) nx=;
if (ny>m) ny=;
if (a[i][j]==k) add(mark[i][j],mark[nx][ny]+adq,,),add(mark[nx][ny]+adq,mark[i][j],,);
else add(mark[i][j],mark[nx][ny]+adq,,),add(mark[nx][ny]+adq,mark[i][j],,-);
}
for (int i=;i<=n;i++)
for (int j=;j<=m;j++)
{
add(S,mark[i][j],,),add(mark[i][j],S,,);
add(mark[i][j]+adq,T,,),add(T,mark[i][j]+adq,,);
}
}
bool Spfa()
{
for (int i=;i<=T;i++)
{
flag[i]=;
dis[i]=INF;
pre[i].init();
}
queue<int>q;
while (!q.empty()) q.pop();
q.push(S);
dis[S]=,flag[S]=;
while (!q.empty())
{
int u=q.front();
q.pop();
for (int i=head[u];i!=-;i=next[i])
{
int v=rea[i],fee=cost[i];
if (dis[u]+fee<dis[v]&&val[i]>)
{
dis[v]=dis[u]+fee;
pre[v].e=i;
pre[v].fa=u;
if (flag[v]==)
{
flag[v]=;
q.push(v);
}
}
}
flag[u]=;
}
if (dis[T]==INF) return ;
else return ;
}
int MFMC()
{
int res=;
while (Spfa())
{
int x=INF;
for (int i=T;pre[i].fa!=-;i=pre[i].fa)
{
int e=pre[i].e;
x=min(x,val[e]);
}
res+=x*dis[T];
for (int i=T;pre[i].fa!=-;i=pre[i].fa)
{
int e=pre[i].e;
val[e]-=x,val[e^]+=x;
}
}
return res;
}
int main()
{
cnt=;
memset(head,-,sizeof(head));
scanf("%d%d",&n,&m);
for (int i=;i<=n;i++)
{
scanf("%s",s);
for (int j=;j<m;j++)
{
mark[i][j+]=(i-)*m+j+;
if (s[j]=='R') a[i][j+]=;
if (s[j]=='D') a[i][j+]=;
if (s[j]=='L') a[i][j+]=;
if (s[j]=='U') a[i][j+]=;
}
}
S=n*m*+,T=n*m*+;
build();
printf("%d\n",MFMC());
}

[Tjoi2013]循环格的更多相关文章

  1. Bzoj 3171: [Tjoi2013]循环格 费用流

    3171: [Tjoi2013]循环格 Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 741  Solved: 463[Submit][Status][ ...

  2. 洛谷 P3965 [TJOI2013]循环格 解题报告

    P3965 [TJOI2013]循环格 题目背景 一个循环格就是一个矩阵,其中所有元素为箭头,指向相邻四个格子. 每个元素有一个坐标(行,列),其中左上角元素坐标为\((0,0)\).给定一个起始位\ ...

  3. BZOJ_3171_[Tjoi2013]循环格_最小费用最大流

    BZOJ_3171_[Tjoi2013]循环格_最小费用最大流 Description 一个循环格就是一个矩阵,其中所有元素为箭头,指向相邻四个格子.每个元素有一个坐标(行,列),其中左上角元素坐标为 ...

  4. bzoj 3171: [Tjoi2013]循环格

    #include<cstdio> #include<iostream> #include<cstring> #define M 10000 #define inf ...

  5. BZOJ3171 Tjoi2013 循环格

    传送门 Description 一个循环格就是一个矩阵,其中所有元素为箭头,指向相邻四个格子.每个元素有一个坐标(行,列),其中左上角元素坐标为(0,0).给定一个起始位置(r,c) ,你可以沿着箭头 ...

  6. 【BZOJ 3171】 [Tjoi2013]循环格

    Description 一个循环格就是一个矩阵,其中所有元素为箭头,指向相邻四个格子.每个元素有一个坐标(行,列),其中左上角元素坐标为(0,0).给定一个起始位置(r,c) ,你可以沿着箭头防线在格 ...

  7. 3171. [TJOI2013]循环格【费用流】

    Description 一个循环格就是一个矩阵,其中所有元素为箭头,指向相邻四个格子.每个元素有一个坐标(行,列),其中左上角元素坐标为(0,0).给定一个起始位置(r,c) ,你可以沿着箭头防线在格 ...

  8. BZOJ 3171 [Tjoi2013]循环格(费用流)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=3171 [题目大意] 一个循环格就是一个矩阵,其中所有元素为箭头,指向相邻四个格子. 每 ...

  9. [TJOI2013]循环格 费用流 BZOJ3171

    题目背景 一个循环格就是一个矩阵,其中所有元素为箭头,指向相邻四个格子.每个元素有一个坐标(行,列),其中左上角元素坐标为(0,0).给定一个起始位(r,c),你可以沿着箭头方向在格子间行走.即:如果 ...

随机推荐

  1. 利用Google浏览器调试js代码

    1.js有两种引入方式,外链和内嵌: 内嵌在浏览中直接调试,外链要在断点处写debugger; 示例代码: <!DOCTYPE html> <html lang="en&q ...

  2. Python金融行业必备工具

    有些国外的平台.社区.博客如果连接无法打开,那说明可能需要"科学"上网 量化交易平台 国内在线量化平台: BigQuant - 你的人工智能量化平台 - 可以无门槛地使用机器学习. ...

  3. jdbc hibernate myBatis比较

    jdbc hibernate myBatis比较 jdbc 优点:性能高,易掌握 缺点:代码繁琐 hibernate 优点:不用写sql,代码简洁 缺点:性能不好 自动生成的sql效率低下(复杂业务) ...

  4. poj 1384完全背包

    题意:给出猪罐子的空质量和满质量,和n个硬币的价值和质量,求猪罐子刚好塞满的的最小价值. 思路:选择硬币,完全背包问题,塞满==初始化为无穷,求最小价值,min. 代码: #include<io ...

  5. 关于javascript原型链的个人理解

    首先js是一种面对对象的语言,虽然大多数时候是以面对过程的形式展现出来.先来看一段代码: function Base() { this.name = 'tarol'; } function Sub() ...

  6. 英语学习APP案例分析

    第一部分 调研, 评测 1.上手体验 界面简洁,有常规的词典翻译功能,针对四六级或考研的人有特别的"单词挑战"模块,以及针对口语训练的"我爱说英语"模块,多功能 ...

  7. 201521123006 《Java程序设计》第6周学习总结

    1. 本周学习总结 1.1 面向对象学习暂告一段落,请使用思维导图,以封装.继承.多态为核心概念画一张思维导图,对面向对象思想进行一个总结. 注1:关键词与内容不求多,但概念之间的联系要清晰,内容覆盖 ...

  8. 201521123050 《Java程序设计》第4周学习总结

    1. 本周学习总结 2. 书面作业 1.注释的应用 1.1使用类的注释与方法的注释为前面编写的类与方法进行注释,并在Eclipse中查看.(截图) 2.面向对象设计(大作业1,非常重要) 2.1 将在 ...

  9. 201521123119《Java程序设计》第4周学习总结

    1. 本周学习总结 2.书面作业 1.注释的应用 使用类的注释与方法的注释为前面编写的类与方法进行注释,并在Eclipse中查看.(截图) 2.面向对象设计(大作业1,非常重要) 2.1 将在网上商城 ...

  10. 微信小程序中发送模版消息注意事项

    在微信小程序中发送模版消息 参考微信公众平台Api文档地址:https://mp.weixin.qq.com/debug/wxadoc/dev/api/notice.html#模版消息管理 此参考地址 ...