bzoj3894,懒得复制题面,戳我戳我

Solution:

  • 首先这是一个网络流,应该还比较好想,主要就是考虑建图了。
  • 我们来分析下题面,因为一个人要么选文科要么选理科,相当于两条流里面割掉一条(怎么想到割我也不知道,颓的题解),那么我们就可以从原点连向每个人,流量为文科愉悦值,然后每个人连向汇点,流量为理科愉悦值。因为要构成最小割,就相当与每条路径一定割一条。
  • 然后我们考虑周围人那个情况,拿文科做例子,我们可以从原点连到一个新点,流量为这个额外愉悦值,然后把这个新节点连向这个周围的五个点(或者四/三个点),理科反过来连到汇点即可,至于为什么这样子可以。下面是解释:



    我们假设割掉所以与原点(\(1\))与文科特殊情况的新点(\(5\))的那条边(假设为边\(A\),图中标记为\(1\))割掉,如果要不练通,显然所有与汇点相连的边都会要割掉,这时候这条\(A\)边显然可以不割,那么这两条边是不会同时留下的(这其实也是显然)
  • 然后我们可以求出最小割,每个割表示的是不选哪种情况,那么最小割就是舍弃的愉悦值最小的情况,我们拿所有愉悦值之和减去最小割即可
  • 貌似有点点卡常,用当前弧优化可以解决
  • 网络流/最小割/费用流的题要多做才会知道建模的套路,不然真的想不到qwq

Code:

//It is coded by ning-mew on 6.28
#include<bits/stdc++.h>
#define FOR for(int i=1;i<=n;i++) for(int j=1;j<=m;j++)
using namespace std; const int maxn=507,INF=1e9+7; int n,m,S=0,T=maxn*maxn*6-1,ANS=0;
int head[maxn*maxn*6],cnt=-1,last[maxn*maxn*6];
struct Edge{int nxt,to,dis;}edge[maxn*maxn*25];
int art[maxn][maxn],sce[maxn][maxn];
int same_art[maxn][maxn],same_sce[maxn][maxn];
int add_x[5]={0,0,0,1,-1},add_y[5]={0,1,-1,0,0}; int Node(int x,int y,int num){
return n*m*(num-1)+(x-1)*m+y;
}
void add(int from,int to,int dis){
edge[++cnt].nxt=head[from];edge[cnt].to=to;
edge[cnt].dis=dis;head[from]=cnt;
}
void Add(int from,int to,int dis){
//cout<<from<<' '<<to<<' '<<dis<<endl;
add(from,to,dis);add(to,from,0);return;
}
struct Network{
int depth[maxn*maxn*6],mark[maxn*maxn*6];
void clear(){
memset(depth,0,sizeof(depth));
memset(mark,0,sizeof(mark));
}
bool bfs(int x){
queue<int>Q;while(!Q.empty())Q.pop();
Q.push(S);depth[S]=1;mark[S]=x;
while(!Q.empty()){
int u=Q.front();Q.pop();
for(int i=head[u];i!=-1;i=edge[i].nxt){
int v=edge[i].to;
if(mark[v]!=x&&edge[i].dis>0){
mark[v]=x;depth[v]=depth[u]+1;
Q.push(v);
}
}
}if(mark[T]==x)return true;return false;
}
int dfs(int u,int dist){
if(u==T)return dist;int d=0;
for(int &i=last[u];i!=-1;i=edge[i].nxt){
int v=edge[i].to;
if(mark[v]==mark[u]&&depth[v]==depth[u]+1&&edge[i].dis>0){
d=dfs(v,min(edge[i].dis,dist));
if(d){
edge[i].dis-=d;edge[i^1].dis+=d;
return d;
}
}
}return 0;
}
int Dinic(){ clear();
int ans=0,d=0,x=2;
while(bfs(++x)){
d=dfs(S,INF);
while(d){/*cout<<"Dinic:"<<d<<endl;*/ans+=d;d=dfs(S,INF);}
for(int i=0;i<=m*n*4;i++)last[i]=head[i];last[T]=head[T];
}return ans;
} }Net;
int main(){
scanf("%d%d",&n,&m);
memset(head,-1,sizeof(head));
FOR scanf("%d",&art[i][j]),ANS+=art[i][j],
Add(S,Node(i,j,1),art[i][j]),Add(Node(i,j,1),Node(i,j,2),INF);
FOR scanf("%d",&sce[i][j]),ANS+=sce[i][j],
Add(Node(i,j,2),T,sce[i][j]);
FOR {
scanf("%d",&same_art[i][j]);ANS+=same_art[i][j];
Add(S,Node(i,j,3),same_art[i][j]);
for(int k=0;k<=4;k++){
int ii=i+add_x[k],jj=j+add_y[k];
if(ii>0&&ii<=n&&jj>0&&jj<=m){
Add(Node(i,j,3),Node(ii,jj,1),INF);
}
}
}
FOR {
scanf("%d",&same_sce[i][j]);ANS+=same_sce[i][j];
Add(Node(i,j,4),T,same_sce[i][j]);
for(int k=0;k<=4;k++){
int ii=i+add_x[k],jj=j+add_y[k];
if(ii>0&&ii<=n&&jj>0&&jj<=m){
Add(Node(ii,jj,2),Node(i,j,4),INF);
}
}
}
printf("%d\n",ANS-Net.Dinic());
return 0;
}

博主蒟蒻,随意转载。但必须附上原文链接:http://www.cnblogs.com/Ning-Mew/,否则你会终生找不到妹子!!!

【题解】 bzoj3894: 文理分科 (网络流/最小割)的更多相关文章

  1. 【bzoj3894】文理分科 网络流最小割

    原文地址:http://www.cnblogs.com/GXZlegend 题目描述 文理分科是一件很纠结的事情!(虽然看到这个题目的人肯定都没有纠结过) 小P所在的班级要进行文理分科.他的班级可以用 ...

  2. [Bzoj3894]文理分科(最小割)

    Description  文理分科是一件很纠结的事情!(虽然看到这个题目的人肯定都没有纠结过)  小P所在的班级要进行文理分科.他的班级可以用一个n*m的矩阵进行描述,每个格子代表一个同学的座位.每位 ...

  3. D - 文理分科 (网络流->最小割)

    题目链接:https://cn.vjudge.net/contest/281959#problem/D 题目大意:中文题目 具体思路:我们需要求出最大的满意值,从另一方面想,我们可以求出总的满意值,然 ...

  4. 【BZOJ3894】文理分科(最小割)

    [BZOJ3894]文理分科(最小割) 题面 BZOJ Description 文理分科是一件很纠结的事情!(虽然看到这个题目的人肯定都没有纠 结过) 小P所在的班级要进行文理分科.他的班级可以用一个 ...

  5. BZOJ_3894_文理分科&&BZOJ_2127_happiness_最小割

    BZOJ_3894_文理分科_最小割 Description  文理分科是一件很纠结的事情!(虽然看到这个题目的人肯定都没有纠 结过)  小P所在的班级要进行文理分科.他的班级可以用一个n*m的矩阵进 ...

  6. [BZOJ 3894] 文理分科 【最小割】

    题目链接:BZOJ - 3894 题目分析 最小割模型,设定一个点与 S 相连表示选文,与 T 相连表示选理. 那么首先要加上所有可能获得的权值,然后减去最小割,即不能获得的权值. 那么对于每个点,从 ...

  7. bzoj 3894 文理分科【最小割+dinic】

    谁说这道和2127是双倍经验的来着完全不一样啊? 数组开小会TLE!数组开小会TLE!数组开小会TLE! 首先sum统计所有收益 对于当前点\( (i,j) \)考虑,设\( x=(i-1)*m+j ...

  8. 【bzoj1143】[CTSC2008]祭祀river Floyd+网络流最小割

    题目描述 在遥远的东方,有一个神秘的民族,自称Y族.他们世代居住在水面上,奉龙王为神.每逢重大庆典, Y族都会在水面上举办盛大的祭祀活动.我们可以把Y族居住地水系看成一个由岔口和河道组成的网络.每条河 ...

  9. Bzoj3894 文理分科

    Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 667  Solved: 389 Description  文理分科是一件很纠结的事情!(虽然看到这个题 ...

随机推荐

  1. you-get帮助使用手册

    you-get使用手册 可选参数:   -V, --version          查看版本并退出   -h, --help             查看帮助信息 不影响使用的选项:   -i, - ...

  2. postgresql总结

    这篇博客主要对PostgreSQL进行总结,内容偏基础. 这里先附上一个PostgreSQL的中文资源:PostgreSQL 8.1 中文文档.英文不好的同学可以看看这个. 安装PostgreSQL ...

  3. 由一个“两次请求”引出的Web服务器跨域请求访问问题的解决方案

    http://blog.csdn.net/cnhnnyzhy/article/details/53128179 (4)Access-Control-Max-Age 该字段可选,用来指定本次预检请求的有 ...

  4. Nginx 负载均衡的Cache缓存批量清理的操作记录

    1)nginx.conf配置 [root@inner-lb01 ~]# cat /data/nginx/conf/nginx.conf user www; worker_processes 8; #e ...

  5. 路由嵌套 active

    http://www.jb51.net/article/102574.htm; https://segmentfault.com/q/1010000008950255 <el-menu :def ...

  6. Beta阶段爬取数目预估

    预计于12月29号能进行Beta版本发布. Beta阶段我们的爬取动作应该更有针对性,在爬取期间如若数据处理小组有需求,会优先爬取数据处理小组提供的种子链接.预估在项目展示之前能够爬取的数目: 普通网 ...

  7. 2-Twenty third Scrum Meeting-20151229

    前言 因为服务器关闭至今,我们的开发项目也遭遇停滞一个星期.与网站开发负责人员协商之后,今天继续开放服务器.我们的项目也能够继续下去.比规定的开发时间(截止为2015/12/29)推迟,因此我们今天又 ...

  8. 用软件工程分析开源项目octave的移植

    在本科的时候学习了软件工程,报考了信息系统项目管理师的考试,,虽然没有过,但是其实还是学了一些相关项目管理方面的知识,,9大管理,,当年应该能背出来,,, 1 项目整体管理 2 项目范围管理 3 项目 ...

  9. html之间传递参数

    转自:http://blog.163.com/yangzhanghui_job/blog/static/179575062201271624839972/ aa.html 往 bb.html 传参 a ...

  10. ADC转换的分辨率

    分辨率是指ADC能够分辨量化的最小信号的能力.分辨率用二进制位数表示.例如对一个10位的ADC,其所能分辨的最小量化电平为参考电平(满量程)的2的10次方分之一.也就是说分辨率越高,就能把满量程里的电 ...