[Tjoi2013]循环格
[Tjoi2013]循环格
Description
Input
第一行两个整数R,C。表示行和列,接下来R行,每行C个字符LRUD,表示左右上下。
Output
一个整数,表示最少需要修改多少个元素使得给定的循环格完美
Sample Input
RRRD
URLL
LRRR
Sample Output
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]循环格的更多相关文章
- Bzoj 3171: [Tjoi2013]循环格 费用流
3171: [Tjoi2013]循环格 Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 741 Solved: 463[Submit][Status][ ...
- 洛谷 P3965 [TJOI2013]循环格 解题报告
P3965 [TJOI2013]循环格 题目背景 一个循环格就是一个矩阵,其中所有元素为箭头,指向相邻四个格子. 每个元素有一个坐标(行,列),其中左上角元素坐标为\((0,0)\).给定一个起始位\ ...
- BZOJ_3171_[Tjoi2013]循环格_最小费用最大流
BZOJ_3171_[Tjoi2013]循环格_最小费用最大流 Description 一个循环格就是一个矩阵,其中所有元素为箭头,指向相邻四个格子.每个元素有一个坐标(行,列),其中左上角元素坐标为 ...
- bzoj 3171: [Tjoi2013]循环格
#include<cstdio> #include<iostream> #include<cstring> #define M 10000 #define inf ...
- BZOJ3171 Tjoi2013 循环格
传送门 Description 一个循环格就是一个矩阵,其中所有元素为箭头,指向相邻四个格子.每个元素有一个坐标(行,列),其中左上角元素坐标为(0,0).给定一个起始位置(r,c) ,你可以沿着箭头 ...
- 【BZOJ 3171】 [Tjoi2013]循环格
Description 一个循环格就是一个矩阵,其中所有元素为箭头,指向相邻四个格子.每个元素有一个坐标(行,列),其中左上角元素坐标为(0,0).给定一个起始位置(r,c) ,你可以沿着箭头防线在格 ...
- 3171. [TJOI2013]循环格【费用流】
Description 一个循环格就是一个矩阵,其中所有元素为箭头,指向相邻四个格子.每个元素有一个坐标(行,列),其中左上角元素坐标为(0,0).给定一个起始位置(r,c) ,你可以沿着箭头防线在格 ...
- BZOJ 3171 [Tjoi2013]循环格(费用流)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=3171 [题目大意] 一个循环格就是一个矩阵,其中所有元素为箭头,指向相邻四个格子. 每 ...
- [TJOI2013]循环格 费用流 BZOJ3171
题目背景 一个循环格就是一个矩阵,其中所有元素为箭头,指向相邻四个格子.每个元素有一个坐标(行,列),其中左上角元素坐标为(0,0).给定一个起始位(r,c),你可以沿着箭头方向在格子间行走.即:如果 ...
随机推荐
- centos 7 最小安装后 ip配置
安装玩CentOS7 后要进行 ip的配置 vi /etc/sysconfig/network-scripts/ifcfg-eth0 在里面输入 NAME=eth0 HWADDR=XX:XX:XX:X ...
- (转载)深入Java关键字this的用法的总结
在Java程序设计中经常会见到this的使用,this使得程序设计变得规范.简单.灵活.但是在使用过程中,在不同场 合它的含义并不完全相同,使用不当还会出现错误, 本文对this的几种用法和出现的问题 ...
- java中的jdk切换(无需卸载原有jdk)
该转自 : http://blog.csdn.net/u010011371/article/details/50749954 很好的一片文章,适合我这种小白,方便以后使用. 之前一直使用的是JDK1 ...
- 微软微服务eShopOnContainers示例之EventBusRabbitMq解析与实践
eShopOnContainers eShopOnContainers是微软官方的微服务架构示例,GitHub地址https://github.com/dotnet-architecture/eSho ...
- poj 3177-3352边双联通
买一送一啊 3177和3352的区别在于3177数据有重边!但是我先做3177的 那么就直接ctrl+c+v搞3352了~. 题意:给一个无向图,要令每个点之间至少有两条不重合的路,需要至少加多少 ...
- visual studio xamarin 离线安装文件以及 android 模拟器
介绍 为了使用vs开发android我也是煞费苦心,先是从网上各种搜刮文章,然后找各种各样的离线包(因为国内网络是下载不了C#/Xamain)的包的,还有各种各样的安装包,都已快接近奔溃的边缘.每次不 ...
- Spring集成RabbitMQ-连接和消息模板
ConnectionFactory ConnectionFactory是RabbitMQ服务掌握连接Connection生杀大权的重要组件 有了它,就可以创建Connection(org.spring ...
- string和double之间的相互转换(C++)
很多人都写过这个标题的文章,但本文要解决的是确保负数的string和double也可以进行转换. 代码如下: string转double double stringToDouble(string nu ...
- 201521123006 《Java程序设计》第7周学习总结
1. 本周学习总结 以你喜欢的方式(思维导图或其他)归纳总结集合相关内容. 2. 书面作业 1.ArrayList代码分析 1.1 解释ArrayList的contains源代码 public boo ...
- 201521123017 《Java程序设计》第2周学习总结
1. 本章学习总结 (1)Arrays和String的用法及其函数的一些运用,例如sort函数,输入多个数字,用Arrays.sort(数组名),对数组中的元素排序,从小到大,与冒泡法对比更加方便使用 ...