题目链接: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 (最大流)的更多相关文章

  1. BZOJ.3532.[SDOI2014]LIS(最小割ISAP 退流)

    BZOJ 洛谷 \(LIS\)..经典模型? 令\(f_i\)表示以\(i\)结尾的\(LIS\)长度. 如果\(f_i=1\),连边\((S,i,INF)\):如果\(f_i=\max\limits ...

  2. [BZOJ]3532: [Sdoi2014]Lis

    Time Limit: 10 Sec  Memory Limit: 512 MB Description 给定序列A,序列中的每一项Ai有删除代价Bi和附加属性Ci.请删除若干项,使得4的最长上升子序 ...

  3. 3532: [Sdoi2014]Lis 最小字典序最小割

    3532: [Sdoi2014]Lis Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 865  Solved: 311[Submit][Status] ...

  4. 3532: [Sdoi2014]Lis

    Description 给定序列A,序列中的每一项Ai有删除代价Bi和附加属性Ci.请删除若干项,使得4的最长上升子序列长度减少至少1,且付出的代价之和最小,并输出方案. 如果有多种方案,请输出将删去 ...

  5. bzoj千题计划141:bzoj3532: [Sdoi2014]Lis

    http://www.lydsy.com/JudgeOnline/problem.php?id=3532 如果没有字典序的限制,那么DP拆点最小割即可 加上字典序的限制: 按c从小到大枚举最小割边集中 ...

  6. [bzoj 1449] 球队收益(费用流)

    [bzoj 1449] 球队收益(费用流) Description Input Output 一个整数表示联盟里所有球队收益之和的最小值. Sample Input 3 3 1 0 2 1 1 1 1 ...

  7. [bzoj3532][Sdoi2014]Lis——拆点最小割+字典序+退流

    题目大意 给定序列A,序列中的每一项Ai有删除代价Bi和附加属性Ci.请删除若 干项,使得4的最长上升子序列长度减少至少1,且付出的代价之和最小,并输出方案. 如果有多种方案,请输出将删去项的附加属性 ...

  8. BZOJ3532 [Sdoi2014]Lis 【网络流退流】

    题目 给定序列A,序列中的每一项Ai有删除代价Bi和附加属性Ci.请删除若 干项,使得4的最长上升子序列长度减少至少1,且付出的代价之和最小,并输出方案. 如果有多种方案,请输出将删去项的附加属性排序 ...

  9. Lis(bzoj 3532)

    Description 给定序列A,序列中的每一项Ai有删除代价Bi和附加属性Ci.请删除若干项,使得4的最长上升子序列长度减少至少1,且付出的代价之和最小,并输出方案.    如果有多种方案,请输出 ...

随机推荐

  1. android模拟器启动没有拨号功能

    网上查询了很多资料, 其中一位网友给出的结论是android 4.3模拟器的bug, 如果在通讯录中添加好友,也是可以进行拨号的. 总结: 自认为是SDK安装程序不完整或设置AVD模拟器的时候设置项出 ...

  2. C语言初学者代码中的常见错误与瑕疵(7)

    问题: 矩形的个数 在一个3*2的矩形中,可以找到6个1*1的矩形,4个2*1的矩形3个1*2的矩形,2个2*2的矩形,2个3*1的矩形和1个3*2的矩形,总共18个矩形.给出A,B,计算可以从中找到 ...

  3. SqlServer 在创建数据库时候指定的初始数据库大小是不能被收缩的

    当你在SqlServer创建数据库的时候可以指定数据库文件的初始大小,比如下图中我们将新创建的数据库MyDB的大小设置成了1024MB 那么你建好的数据库的确也就会占用1024MB左右的磁盘空间 不过 ...

  4. Jquery Ajax调用aspx页面方法 (转载)

    在asp.net webform开发中,用jQuery ajax传值一般有几种玩法 1)普通玩法:通过一般处理程序ashx进行处理: 2)高级玩法:通过aspx.cs中的静态方法+WebMethod进 ...

  5. Test Android with QTP

    by Yaron Assa I have recently come across a plug-in to QTP that enables to automate tests on Android ...

  6. 69道Java Spring 面试&笔试题

    目录 Spring 概述 依赖注入 Spring beans Spring注解 Spring数据访问 Spring面向切面编程(AOP) Spring MVC Spring 概述 1. 什么是spri ...

  7. 161114、websocket实现心跳重连

    心跳重连缘由 在使用websocket过程中,可能会出现网络断开的情况,比如信号不好,或者网络临时性关闭,这时候websocket的连接已经断开, 而浏览器不会执行websocket 的 onclos ...

  8. E2PROM的尺寸

    买的E2PROM是128*8bit的, 就是只能存储128个byte, 妈的, 买小了. 实际需要的是10句, 可能加两个特殊句, "新手"跟"故障", 一共1 ...

  9. C# csv 操作类

    using System.Data; using System.IO; using System.Text; namespace YanZhiwei.DotNet2.Utilities.Common ...

  10. iOS直播的技术分析与实现

    HTTP Live Streaming直播(iOS直播)技术分析与实现 发布于:2014-05-28 13:30阅读数:12004 HTTP Live Streaming直播(iOS直播)技术分析与实 ...