当前位置: 首页 > 编程日记 > 正文

洛谷P3159 [CQOI2012]交换棋子

巧妙的拆点方式,首先把1看成黑点,0看成空的,几次交换就可以看成一条路径

1)从容量上看,这条路径为1-2-2-2-2-2-……-2-1

2)从费用上看,这条路径每条边费用都是1

于是用一种巧妙的拆点方式,把一个点拆成三个,连两条边,成为一条链,

然后如果是黑点的话就由s向中间那个点连边,如果是路过的话就由一条链的尾部向另一条链的首部连边

这样就满足了上面的条件1)2)

容量的话如果是黑点出来就是(c+1)/2,进来是c/2,其他的以此类推

  1 #include<cstdio>
  2 #include<cstdlib>
  3 #include<algorithm>
  4 #include<cstring>
  5 #include<vector>
  6 #include<queue>
  7 #define rint register int
  8 #define ll long long
  9 #define MAXN 2000+10
 10 #define pb push_back
 11 #define INF 0x7f7f7f7f
 12 #define oo 0x7f7f7f7f7f7f7f7f
 13 #define pil pair<int,ll>
 14 #define mp make_pair
 15 using namespace std;
 16 int read(){
 17     int x=0,f=1;char ch=getchar();
 18     while(ch<'0'||ch>'9'){if('-'==ch)f=-1;ch=getchar();}
 19     while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}
 20     return x*f;
 21 }
 22 struct E{
 23     int from,to,cap,flow;
 24     ll cost;
 25     E(int x=0,int y=0,int c=0,int f=0,ll w=0LL){
 26         from=x,to=y,cap=c,flow=f,cost=w;
 27     }
 28 };
 29 struct Dinic{
 30     int n,m,s,t;
 31     vector<E> es;
 32     vector<int> G[MAXN];
 33     void init(int n,int s,int t){
 34         this->n=n;
 35         this->s=s,this->t=t;
 36         es.clear();
 37         for(int i=0;i<=n;i++)G[i].clear();
 38     }
 39     void add(int x,int y,int cap,ll cost){
 40         es.pb(E(x,y,cap,0,cost));
 41         es.pb(E(y,x,0,0,-cost));
 42         m=es.size();
 43         G[x].pb(m-2),G[y].pb(m-1);
 44     }
 45     int p[MAXN],a[MAXN];
 46     ll d[MAXN];
 47     int b[MAXN];
 48     bool SPFA(int &flow,ll &cost){
 49         p[s]=0,a[s]=INF;
 50         memset(d,0x7f,sizeof(d));
 51         d[s]=0;
 52         memset(b,0,sizeof(b));
 53         b[s]=1;
 54         queue<int> q;
 55         q.push(s);
 56         while(!q.empty()){
 57             int x=q.front();q.pop();b[x]=0;
 58             for(rint i=0;i<G[x].size();i++){
 59                 E &e=es[G[x][i]];
 60                 if(e.cap>e.flow&&d[e.to]>d[x]+e.cost){
 61                     p[e.to]=G[x][i];
 62                     a[e.to]=min(a[x],e.cap-e.flow);
 63                     d[e.to]=d[x]+e.cost;
 64                     if(!b[e.to]){
 65                         b[e.to]=1;
 66                         q.push(e.to);
 67                     }
 68                 }
 69             }
 70         }
 71         if(oo==d[t]){
 72             return 0;
 73         }
 74         flow+=a[t];
 75         cost+=a[t]*d[t];
 76         for(rint i=t;i!=s;i=es[p[i]].from){
 77             es[p[i]].flow+=a[t];
 78             es[p[i]^1].flow-=a[t];
 79         }
 80         return 1;
 81     }
 82     pil MaxfMinc(){
 83         int flow=0;
 84         ll cost=0LL;
 85         while(SPFA(flow,cost));
 86         return mp(flow,cost);
 87     }
 88 }D;
 89 int n,m,s=0,t=MAXN-1;
 90 int id[3][25][25];
 91 int a[25][25],b[25][25],p[25][25];
 92 int cnt1=0,cnt2=0;
 93 void init(){
 94     n=read();m=read();
 95     D.init(t,s,t);
 96     char c[25];
 97     for(rint i=1;i<=n;i++){
 98         for(rint j=1;j<=m;j++){
 99             id[0][i][j]=(i-1)*m+j;
100         }
101     }
102     for(rint k=1;k<=2;k++){
103         for(rint i=1;i<=n;i++){
104             for(rint j=1;j<=m;j++){
105                 id[k][i][j]=id[k-1][i][j]+n*m;
106             }
107         }
108     }
109     for(rint i=1;i<=n;i++){
110         scanf("%s",c+1);
111         for(rint j=1;j<=m;j++){
112             a[i][j]=c[j]-'0';
113         }
114     }
115     for(rint i=1;i<=n;i++){
116         scanf("%s",c+1);
117         for(rint j=1;j<=m;j++){
118             b[i][j]=c[j]-'0';
119         }
120     }
121     for(rint i=1;i<=n;i++){
122         for(rint j=1;j<=m;j++){
123             if(a[i][j]&&b[i][j]){
124                 a[i][j]=b[i][j]=0;
125             }    
126             else if(a[i][j]){
127                 cnt1++;
128             }
129             else if(b[i][j]){
130                 cnt2++;
131             }
132         }
133     }
134     for(rint i=1;i<=n;i++){
135         scanf("%s",c+1);
136         for(rint j=1;j<=m;j++){
137             p[i][j]=c[j]-'0';
138         }
139     }
140 }
141 void add(int x,int y,int c1,int c2){
142     D.add(id[0][x][y],id[1][x][y],c1,0);
143     D.add(id[1][x][y],id[2][x][y],c2,0);
144 }
145 void solve(){
146     int dx[8]={0,0,-1,1,-1,-1,1,1};
147     int dy[8]={1,-1,0,0,-1,1,-1,1};
148     for(rint i=1;i<=n;i++){
149         for(rint j=1;j<=m;j++){
150             if(a[i][j]){
151                 add(i,j,p[i][j]>>1,(p[i][j]+1)>>1);
152                 D.add(s,id[1][i][j],1,0);
153             }
154             else if(b[i][j]){
155                 add(i,j,(p[i][j]+1)>>1,p[i][j]>>1);
156                 D.add(id[1][i][j],t,1,0);
157             }
158             else{
159                 add(i,j,(p[i][j]+1)>>1,p[i][j]>>1);                
160             }
161             for(rint k=0;k<8;k++){
162                 int x=i+dx[k],y=j+dy[k];
163                 if(1<=x&&x<=n&&1<=y&&y<=m){
164                     D.add(id[2][i][j],id[0][x][y],INF,1);
165                 }
166             }
167         }
168     }
169     pil ans=D.MaxfMinc();
170     if(ans.first!=cnt1||cnt1!=cnt2){
171         printf("-1\n");
172     }
173     else{
174         printf("%d\n",ans.second);
175     }
176 }
177 int main()
178 {
179     init();
180     solve();
181     return 0;
182 }

转载于:https://www.cnblogs.com/w-h-h/p/8453004.html

相关文章:

趣谈iOS运行时的方法调用原理

一个成熟的计算机语言必然有丰富的体系&#xff0c;复杂的容错机制&#xff0c;处理逻辑以及判断逻辑。但这些复杂的逻辑都是围绕一个主线丰富和展开的&#xff0c;所以在学习计算机语言的时候&#xff0c;先掌握核心&#xff0c;然后了解其原理&#xff0c;明白程序语言设计的…

GCD实现倒计时

__block int timeout59; //倒计时时间dispatch_queue_t queue dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);dispatch_source_t _timer dispatch_source_create(DISPATCH_SOURCE_TYPE_TIMER, 0, 0,queue);dispatch_source_set_timer(_timer,dispatch_wall…

Solidity基础入门知识(十)函数的访问权限和可见性

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自链客区块链技术问答社区&#xff0c;未经允许拒绝转载。 下面来继续介绍作为一个分布式网络语言所特有的internal和external这两种不同的函数调用方式&#xff0c;以及Solidity提供的对函数调用时的…

Sass (Syntactically Awesome StyleSheets)

Sass (Syntactically Awesome StyleSheets) Sass 是对 CSS 的扩展&#xff0c;让 CSS 语言更强大、优雅。 它允许你使用变量、嵌套规则、 mixins、导入等众多功能&#xff0c; 并且完全兼容 CSS 语法。 Sass 有助于保持大型样式表结构良好&#xff0c; 同时也让你能够快速开始小…

键盘的相关设置

一、键盘风格 UIKit框架支持8种风格键盘。 typedef enum { UIKeyboardTypeDefault, // 默认键盘&#xff1a;支持所有字符 UIKeyboardTypeASCIICapable, // 支持ASCII的默认键盘 UIKeyboardTypeNumbersAndPunctuation, // 标准电…

python全栈开发基础【第十七篇】面向对象反射和内置方法

一、静态方法&#xff08;staticmethod&#xff09;和类方法&#xff08;classmethod&#xff09; 类方法&#xff1a;有个默认参数cls,并且可以直接用类名去调用&#xff0c;可以与类属性交互&#xff08;也就是可以使用类属性&#xff09; 静态方法&#xff1a;让类里的方法直…

区块链笔记分享

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自链客区块链技术问答社区&#xff0c;未经允许拒绝转载。 区块链笔记分享:技术和数学基础: 高位的hash的逆向过程除了穷举&#xff0c;没有更有效的办法&#xff0c;这个过程在目前的计算能力下必然…

BZOJ4766: 文艺计算姬

Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 737 Solved: 402[Submit][Status][Discuss]Description "奋战三星期&#xff0c;造台计算机"。小W响应号召&#xff0c;花了三星期造了台文艺计算姬。文艺计算姬比普通计算机有更多的艺术细胞。普通计算机能计算一个…

Android调用远程Service的参数和返回值都需要实现Parcelable接口

import android.os.Parcel;import android.os.Parcelable; public class Person implements Parcelable{   private Integer id;   private String name;   private String pass;   public Person() {     super();   } public Person(Integer id, String name, …

git的简单命令

git init 初始化管理库 git add file_name 将文件添加到文件管理库 git commit -m “xxx” 将文件提交到文件管理库&#xff08;xxx&#xff1a;说明文字&#xff09; git status 查看当前状态 git diff 查看文件改动的地方 git log 查看历史版本提交记录(如果觉…

区块链概念:Hash 算法

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自链客区块链技术问答社区&#xff0c;未经允许拒绝转载。 区块链概念1&#xff1a;Hash 算法 作用在学习哈希算法前&#xff0c;我们需要知道哈希在区块链的作用哈希算法的作用如下&#xff1a;区块…

java 文件操作

文件操作——File File表示目录信息 listFiles方法 File的listFiles方法用于返回一个抽象路径名数组&#xff0c;这些路径名表示此抽象路径名表示的目录中的文件。其方法定义: File[] listFiles()返回值&#xff1a;抽象路径名数组&#xff0c;这些路径名表示此抽象路径名表示的…

三维等值面提取算法(Dual Contouring)

上一篇介绍了Marching Cubes算法&#xff0c;Marching Cubes算法是三维重建算法中的经典算法&#xff0c;算法主要思想是检测与等值面相交的体素单元并计算交点的坐标&#xff0c;然后对不同的相交情况利用查找表在体素单元内构建相应的网格拓扑关系。Marching Cubes算法简单&a…

设置status bar的颜色

statusBar显示电池电量、时间、网络部分标示的颜色只能设置两种颜色&#xff1a; 默认的黑色&#xff08;UIStatusBarStyleDefault&#xff09;白色&#xff08;UIStatusBarStyleLightContent&#xff09; 配置info.plist文件 1.View controller-based status bar appearance…

EOS与以太坊有哪些区别?

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自链客区块链技术问答社区&#xff0c;未经允许拒绝转载。 以太坊是一个专门为开发和运行去中心化应用&#xff08;DAPP&#xff09;搭建的智能合约平台&#xff1b;EOS与以太坊类似&#xff0c;同样…

Quartz 2D基本图形的绘制

基本步骤&#xff1a; 1.获取绘图上下文 2.创建并设置路径 3.将路径添加到上下文 4.设置上下文状态 5.绘制路径 6.释放路径 #import "YGView.h" //屏幕尺寸#define kScreenSize [UIScreen mainScreen].bounds.size//屏幕宽高定义#define kscreenWidth [[UIScr…

命令行程序增加 GUI 外壳

Conmajia © 2012 Updated on Feb. 21, 2018 命令行大家都用过&#xff1a; 图 1 命令行程序工作界面 现在想办法为它做一个 GUI 外壳&#xff0c;实际效果参考图 2. 图 2 带 GUI 外壳的命令行程序 程序思路是这样的&#xff1a; 通过运行 cmd.exe 来操作命令行&#xff0c…

人月神话阅读笔记07

第1章 焦油坑焦油坑的意思说明了即使你足够强大&#xff0c;也无法摆脱束搏而沉到坑底。IT项目也是这样&#xff0c;不论是开发大型软件系统还是小型项目&#xff0c;都会遇到诸多复杂的问题和影响因素&#xff0c;项目本身就是一个足够复杂的动态系统&#xff0c;没有最优&…

区块链隐私:交易还是计算?

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自链客区块链技术问答社区&#xff0c;未经允许拒绝转载。 区块链隐私&#xff1a;交易还是计算&#xff1f; 隐私”是什么意思?在区块链生态系统中&#xff0c;“隐私”这个词被用于许多不同的语…

8 ServletContext

1 为什么需要ServletContext 技术 显示网站多少人在线&#xff0c;显示当前登录者是第几位登录者等信息。 2 什么是ServletContext 可以把它想象成一个服务器上的公共空间&#xff0c;每个用户都可以访问到它。 Web 容器在启动时&#xff0c;它会为每个Web 应用程序都创建一个对…

IOS沙盒Files目录说明和常用操作

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { // 读取Documents目录代码 NSArray *pathsDocumentsNSSearchPathForDirectoriesInDomains(NSDocumentDirectory,NSUserDomainMask,YES); NSString *pathDocu…

iOS一些实用的技巧

获取触摸的点- (CGPoint)locationInView:(UIView *)view; - (CGPoint)previousLocationInView:(UIView *)view;自动适应父视图大小self.view.autoresizesSubviews YES;self.view.autoresizingMask UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleHeight;把pli…

在公共区块链中通过加密保护数据

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自链客区块链技术问答社区&#xff0c;未经允许拒绝转载。 隐私限制 在处理或交换业务文件时&#xff0c;贸易伙伴可能需要某些隐私因素。 (1)交易数据的隐私性: 交易数据仅供交易双方阅读。 (2)交…

python xml模块学习

xml打开方式 # xml有两种打开方式 # 1. 打开文件&#xff0c;读取XML内容 str_xml open(xman.xml, r).read() print(str_xml)# 将字符串解析成xml特殊对象&#xff0c;root代指xml文件的根节点 root ET.XML(str_xml) # 读取字符串&#xff0c;将字符串转为Element对象 pri…

实例 - 购物车 (列表、循环)

salary int(input(Please input your money:))product [(iphone6s,5800),(mac bood,9000),(coffee,32),(python book,80),(bicyle,1500), ]shopping []while True:#打印商品内容n 1for i,v in product:print(n,.,i,v)n 1#引导用户选择商品choice input(选择购买商品编号:…

右滑手势导航返回的相关设置

iOS7之后提供了右滑返回上一级界面的手势&#xff0c;但是自定义返回按钮会失效&#xff0c;解决办法如下&#xff1a; -(void)viewWillAppear:(BOOL)animated{ [superviewWillAppear:animated]; if([self.navigationController respondsToSelector:selector(interacti…

区块链编程完全指南:平台、语言与结论

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自链客区块链技术问答社区&#xff0c;未经允许拒绝转载。 区块链&#xff0c;代表着未来的发展方向。是的&#xff0c;在文章开头&#xff0c;我们首先给出这样的结论。当然&#xff0c;认定未来将围…

基于QProbe创建基本Android图像处理框架

先来看一个GIF 这个GIF中有以下几个值得注意的地方这个界面是基本的主要界面所应该在的地方。其右下角有一个“”号&#xff0c;点击后&#xff0c;打开图像采集界面在这个界面最上面的地方&#xff0c;显示的是当前图像处理的状态。&#xff08;一般来说&#xff0c;是成功/不…

iOS三种拨打电话的方法

1&#xff0c;这种方法&#xff0c;拨打完电话回不到原来的应用&#xff0c;会停留在通讯录里&#xff0c;而且是直接拨打&#xff0c;不弹出提示NSMutableString* str[[ NSMutableStringalloc ] initWithFormat : "tel:%" , "xxxxxxxxxxx" ];[[UIApplica…

查询今天是周几?

<?php $wdate(w); $weekarray( "0">"星期日", "1">"星期一", "2">"星期二", "3">"星期三", "4">"星期四", "5">"星期五",…