BZOJ 3532: [Sdoi2014]Lis (最大流)
题目链接:http://www.lydsy.com:808/JudgeOnline/problem.php?id=3532
题意:给出三个数列ABC,长度均为n。删除A中的某些数字,使得A的最长上升子列至少减少1。删掉的数字的代价为相应的B值之和。要求使得代价最小。多组答案时,使得删掉的数字的C值排序的字典序最小。
思路:假设不考虑字典序。那么只要拆点求最小割即可。设f[i]表示到i的最长上升子列。对于两个数字(i,j),若A[i]<A[j]且f[i]+1=f[j],则i向j连边。对于每个点拆开的点连边为B值。
现在要求字典序最小,首先按照C排序,然后从小到大枚举。对于数字x判断其是否在最小割中。若其代表的边(x1,x2)之间的流量为0,且在残留网络中x1不能到达x2,那么x在最小割中。之后还要去掉x这条边。只需要将这条边以及反向边的流量设为0,同时跑(T,x2)(x1,S)的最大流即可,这样可以恢复x原来的边带来的影响。
const int INF=2000000005; const int N=1444; struct node { int v,next; int cap; }; node edges[1100000]; int head[N],e; int curedge[N]; inline void add(int u,int v,int cap) { edges[e].v=v; edges[e].cap=cap; edges[e].next=head[u]; head[u]=e++; } inline void Add(int u,int v,i64 cap) { add(u,v,cap); add(v,u,0); } int S,T; int dis[N]; int Q[N]; int bfs(int s,int t) { clr(dis,-1); int i; for(i=S;i<=T;i++) curedge[i]=head[i]; int L=0,R=0; dis[t]=0; Q[R++]=t; while(L<R) { int u=Q[L++]; for(i=head[u];i!=-1;i=edges[i].next) { if(edges[i^1].cap&&-1==dis[edges[i].v]) { dis[edges[i].v]=dis[u]+1; Q[R++]=edges[i].v; if(edges[i].v==s) return 1; } } } return 0; } int DFS(int u,int det,int t) { if(u==t) return det; int now=0; int i; for(int &i=curedge[u];i!=-1&&det;i=edges[i].next) { int v=edges[i].v; int w=edges[i].cap; if(w&&dis[u]==dis[v]+1) { int tmp=DFS(v,min(w,det),t); if(tmp==0) continue; edges[i].cap-=tmp; edges[i^1].cap+=tmp; now+=tmp; det-=tmp; } } return now; } int dinic(int s,int t) { int ans=0; while(bfs(s,t)) ans+=DFS(s,INF,t); return ans; } pair<int,int> C[777]; int A[777],B[777]; int n; int f[777]; int num[777]; int main() { int cse=getInt(); while(cse--) { n=getInt(); int i; for(i=1;i<=n;i++) A[i]=getInt(); for(i=1;i<=n;i++) B[i]=getInt(); for(i=1;i<=n;i++) C[i].first=getInt(),C[i].second=i; int j; int Max=1; for(i=1;i<=n;i++) { f[i]=1; for(j=1;j<i;j++) if(A[j]<A[i]) f[i]=max(f[i],f[j]+1); Max=max(Max,f[i]); } clr(head,-1); e=0; S=0,T=n+n+1; for(i=1;i<=n;i++) { num[i]=e; Add(i*2-1,i*2,B[i]); if(f[i]==1) Add(S,i*2-1,INF); if(f[i]==Max) Add(i*2,T,INF); for(j=i+1;j<=n;j++) if(A[i]<A[j]&&f[i]+1==f[j]) Add(i*2,j*2-1,INF); } int ans=dinic(S,T); sort(C+1,C+n+1); int a[777],aNum=0; for(i=1;i<=n;i++) { int t=C[i].second; int k=num[t]; if(edges[k].cap!=0) continue; if(bfs(t*2-1,t*2)) continue; dinic(T,t*2); dinic(t*2-1,S); edges[k^1].cap=0; a[++aNum]=C[i].second; } sort(a+1,a+aNum+1); printf("%d %d\n",ans,aNum); for(i=1;i<=aNum;i++) { if(i>1) putchar(' '); printf("%d",a[i]); } puts(""); } }
BZOJ 3532: [Sdoi2014]Lis (最大流)的更多相关文章
- BZOJ.3532.[SDOI2014]LIS(最小割ISAP 退流)
BZOJ 洛谷 \(LIS\)..经典模型? 令\(f_i\)表示以\(i\)结尾的\(LIS\)长度. 如果\(f_i=1\),连边\((S,i,INF)\):如果\(f_i=\max\limits ...
- [BZOJ]3532: [Sdoi2014]Lis
Time Limit: 10 Sec Memory Limit: 512 MB Description 给定序列A,序列中的每一项Ai有删除代价Bi和附加属性Ci.请删除若干项,使得4的最长上升子序 ...
- 3532: [Sdoi2014]Lis 最小字典序最小割
3532: [Sdoi2014]Lis Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 865 Solved: 311[Submit][Status] ...
- 3532: [Sdoi2014]Lis
Description 给定序列A,序列中的每一项Ai有删除代价Bi和附加属性Ci.请删除若干项,使得4的最长上升子序列长度减少至少1,且付出的代价之和最小,并输出方案. 如果有多种方案,请输出将删去 ...
- bzoj千题计划141:bzoj3532: [Sdoi2014]Lis
http://www.lydsy.com/JudgeOnline/problem.php?id=3532 如果没有字典序的限制,那么DP拆点最小割即可 加上字典序的限制: 按c从小到大枚举最小割边集中 ...
- [bzoj 1449] 球队收益(费用流)
[bzoj 1449] 球队收益(费用流) Description Input Output 一个整数表示联盟里所有球队收益之和的最小值. Sample Input 3 3 1 0 2 1 1 1 1 ...
- [bzoj3532][Sdoi2014]Lis——拆点最小割+字典序+退流
题目大意 给定序列A,序列中的每一项Ai有删除代价Bi和附加属性Ci.请删除若 干项,使得4的最长上升子序列长度减少至少1,且付出的代价之和最小,并输出方案. 如果有多种方案,请输出将删去项的附加属性 ...
- BZOJ3532 [Sdoi2014]Lis 【网络流退流】
题目 给定序列A,序列中的每一项Ai有删除代价Bi和附加属性Ci.请删除若 干项,使得4的最长上升子序列长度减少至少1,且付出的代价之和最小,并输出方案. 如果有多种方案,请输出将删去项的附加属性排序 ...
- Lis(bzoj 3532)
Description 给定序列A,序列中的每一项Ai有删除代价Bi和附加属性Ci.请删除若干项,使得4的最长上升子序列长度减少至少1,且付出的代价之和最小,并输出方案. 如果有多种方案,请输出 ...
随机推荐
- PAT乙级 1011. A+B和C (15)
1011. A+B和C (15) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 HOU, Qiming 给定区间[-231, 231 ...
- UITableView(转)
一.UITableView概述 UITableView继承自UIScrollView,可以表现为Plain和Grouped两种风格,分别如下图所示: 其中左边的是Plain风格的,右 ...
- 搭建无限制权限的简单git服务器使用git-daemon脚本
如果想要用ubantu架设无限制权限(即不适用gitosis)的简单git服务器,实现git库下载clone,push等简单的基本功能, 可以直接使用git-daemon脚本(非常不安全,建议项目代码 ...
- jQuery DataTable-JavaScript API
虽然大多数时候你的Javascript交互将通过使用datatable初始化对象作为描述在使用这个网站的部分,有时,你会发现它有用一些外部控制表.可以使用以下函数从jQuery.dataTable对象 ...
- init_MUTEX 与 sema_init 函数【转】
转自:http://blog.chinaunix.net/uid-7332782-id-3211627.html 在编译Linux设备驱动程序学习(1)-字符设备驱动程序中scull.c程序时,报错: ...
- Mysql备份与还原实例
一.备份数据库 ----清空一下日志 mysql> reset master; Query OK, rows affected (0.02 sec) ----查看一下echo表的存储引擎 mys ...
- Sqoop安装及操作
一.集群环境: Hostname IP Hadoop版本 Hadoop 功能 系统 node1 192.168.1.151 0.20.0 namenode hive+sqoop rhel5.4X86 ...
- PHP多表取数据的代码优化
<?php header("Content-type: text/html; charset=utf-8"); //假设这里的$goods_arr 和 $shop_arr ...
- Codeforces 741B:Arpa's weak amphitheater and Mehrdad's valuable Hoses(01背包+并查集)
http://codeforces.com/contest/741/problem/B 题意:有 n 个人,每个人有一个花费 w[i] 和价值 b[i],给出 m 条边,代表第 i 和 j 个人是一个 ...
- 各种drawable
BitmapDrawable 可以把小图片平铺布满布局来设置背景. PictureDrawable 记录绘制过程 ClipDrawable 裁剪 进度条 InsetDrawabl ...