正解:网络流

解题报告:

传送门$QwQ$

恩先不考虑关于那个附加属性的限制,考虑这题怎么做?

首先这题从名字开始就让人忍不住联想起网络流24题里的那个最长不下降子序列?于是同样考虑预处理一个$f$呗

然后再一看,长得就很最小割嘛,于是拆点,能构成最长不下降子序列的之间就连权值为$inf$的边,$f_{i}=1$的点和$S$.$f_{i}=mxf$的点和$T$连权值为$inf$的边,拆开的点之间连权值为$b_{i}$的边.跑个最小割就好$QwQ$

现在考虑怎么搞那个附加属性$QwQ$?

$umm$这需要一个前置芝士,就关于最小割的可行边和必须边.结论可以翻我滴.$AHOI2009$最小割那题题解$QwQ$

好现在就当作知道结论了,就说如果一条边$x,y$是一条可行边说明$x$到$y$没有路径,所以按附加属性从小到大枚举$c$,若是可行边,显然就把这条边加入答案,考虑到这条边只是一条可行边并不是必然边?所以要继续考虑的话就要将和这条边等价的边的影响删除掉.

考虑到这些等价边显然在$S$到$x$,$y$到$T$的路径上,所以就在$x$到$S$,$y$到$T$上跑个最大流退流就好$QwQ$.感性理解下大概应该是能$get$的?

昂还有一个点忘说了,就一个卡常技巧,在$bfs$中只需要搜到$T$就可以直接$return$了(我印象中,在$bfs$中从$T$拓展到$S$的效果是一样的?$QwQ$

然后细心点儿注意细节,记得初始化

$over$

#include<bits/stdc++.h>
using namespace std;
#define il inline
#define gc getchar()
#define t(i) edge[i].to
#define w(i) edge[i].wei
#define n(i) edge[i].nxt
#define ri register int
#define rb register int
#define rc register char
#define rp(i,x,y) for(ri i=x;i<=y;++i)
#define my(i,x,y) for(ri i=x;i>=y;--i)
#define e(i,x) for(ri i=head[x];~i;i=n(i)) const int N=,inf=1e9;
int n,dep[N],head[N],cur[N],S,T,ed_cnt=-,mxf,f[N],as_cnt,ed_nam[N],as[N];
struct ed{int to,nxt,wei;}edge[N<<];
struct node{int a,b,c,id;}nod[N]; il int read()
{
rc ch=gc;ri x=;rb y=;
while(ch!='-' && (ch>'' || ch<''))ch=gc;
if(ch=='-')ch=gc,y=;
while(ch>='' && ch<='')x=(x<<)+(x<<)+(ch^''),ch=gc;
return y?x:-x;
}
il bool cmp(node gd,node gs){return gd.c<gs.c;}
il void ad(ri x,ri y,ri z)
{
//printf("%d -> %d : %d\n",y,x,z);
edge[++ed_cnt]=(ed){x,head[y],z};head[y]=ed_cnt;edge[++ed_cnt]=(ed){y,head[x],};head[x]=ed_cnt;}
il bool bfs(ri s,ri t)
{
queue<int>Q;Q.push(s);memset(dep,,sizeof(dep));dep[s]=;
while(!Q.empty())
{ri nw=Q.front();Q.pop();e(i,nw)if(w(i) && !dep[t(i)]){dep[t(i)]=dep[nw]+,Q.push(t(i));if(t(i)==t)return ;}}
return ;
}
il int dfs(ri nw,ri flow,ri t)
{
if(nw==t || !flow)return flow;ri ret=;
for(ri &i=cur[nw];~i;i=n(i))
if(w(i) && dep[t(i)]==dep[nw]+){ri d=dfs(t(i),min(flow,w(i)),t);w(i)-=d,flow-=d,ret+=d,w(i^)+=d;}
return ret;
}
il int dinic(ri s,ri t)
{ri ret=;while(bfs(s,t)){rp(i,S,T)cur[i]=head[i];while(int d=dfs(s,inf,t))ret+=d;}return ret;} int main()
{
//freopen("3308.in","r",stdin);freopen("3308.out","w",stdout);
ri tmp=read();
while(tmp--)
{
n=read();S=;T=n*+;as_cnt=;memset(head,-,sizeof(head));memset(f,,sizeof(f));mxf=;
rp(i,,n)nod[i].a=read(),nod[i].id=i;rp(i,,n)nod[i].b=read();rp(i,,n)nod[i].c=read();
my(i,n,){f[i]=;rp(j,i+,n)if(nod[j].a>nod[i].a)f[i]=max(f[i],f[j]+);mxf=max(mxf,f[i]);}
rp(i,,n)
{
if(f[i]==mxf)ad(T,i+n,inf);
if(f[i]==)ad(i,S,inf);
ad(i+n,i,nod[i].b);ed_nam[i]=ed_cnt;
rp(j,i+,n)if(f[j]==f[i]- && nod[j].a>nod[i].a)ad(i,j+n,inf);
}
printf("%d ",dinic(S,T));sort(nod+,nod++n,cmp);
rp(i,,n)
if(!bfs(nod[i].id,nod[i].id+n))
{
//printf("???halo???\n");
as[++as_cnt]=nod[i].id;dinic(nod[i].id,S);dinic(T,nod[i].id+n);
w(ed_nam[nod[i].id])=,w(ed_nam[nod[i].id]^)=;
}
sort(as+,as+as_cnt+);printf("%d\n",as_cnt);rp(i,,as_cnt)printf("%d ",as[i]);printf("\n");
}
return ;
}

洛谷$P3308\ [SDOI2014]LIS$ 网络流的更多相关文章

  1. 洛咕3312 [SDOI2014]数表

    洛咕3312 [SDOI2014]数表 终于独立写出一道题了...真tm开心(还是先写完题解在写的) 先无视a的限制,设\(f[i]\)表示i的约数之和 不妨设\(n<m\) \(Ans=\su ...

  2. 洛谷P1251 餐巾(网络流)

    P1251 餐巾 15通过 95提交 题目提供者该用户不存在 标签网络流贪心 难度提高+/省选- 提交该题 讨论 题解 记录 最新讨论 为什么我全部10个测试点都对… 题目描述 一个餐厅在相继的N天里 ...

  3. 3150luogu洛谷

    若说代码 那真的是很水 但是 思想却有点意思 这道题是洛谷博弈论专题的第一道入门题, 然而刚开始我是不会做的, 毕竟是道入门题, 我博弈论还没入门呢. 这道题的做法就是: 如果m为偶数, 那么先手赢( ...

  4. 洛谷 P3313 [SDOI2014]旅行 解题报告

    P3313 [SDOI2014]旅行 题目描述 S国有N个城市,编号从1到N.城市间用N-1条双向道路连接,满足从一个城市出发可以到达其它所有城市.每个城市信仰不同的宗教,如飞天面条神教.隐形独角兽教 ...

  5. [SDOI2014]LIS

    这道题还是非常好的 首先第一问可以让我们联想到某网络流二十四题里的一道题,发现建图方式应该和这道题差不多啊 所以首先跑一遍\(dp\),求出\(dp[i]\)表示\(i\)位置结束的\(LIS\)长度 ...

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

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

  7. 洛谷 P3312 [SDOI2014]数表 解题报告

    P3312 [SDOI2014]数表 题目描述 有一张\(N*M\)的数表,其第\(i\)行第\(j\)列(\(1\le i \le n\),\(1 \le j \le m\))的数值为能同时整除\( ...

  8. 洛谷P3312 - [SDOI2014]数表

    Portal Solution 共\(T(T\leq2\times10^4)\)组测试数据.给出\(n,m(n,m\leq10^5),a(a\leq10^9)\),求\[ \sum_{i=1}^n\s ...

  9. P1219 八皇后 洛谷

    题目描述 检查一个如下的6 x 6的跳棋棋盘,有六个棋子被放置在棋盘上,使得每行.每列有且只有一个,每条对角线(包括两条主对角线的所有平行线)上至多有一个棋子. 上面的布局可以用序列2 4 6 1 3 ...

随机推荐

  1. @loj - 2461@ 「2018 集训队互测 Day 1」完美的队列

    目录 @description@ @solution@ @part - 0@ @part - 1@ @accepted code@ @details@ @description@ 小 D 有 n 个 ...

  2. @bzoj - 3836@ [Poi2014]Tourism

    目录 @description@ @solution@ @accepted code@ @details@ @description@ 给定一个n个点,m条边的无向图,其中你在第i个点建立旅游站点的费 ...

  3. IntelliJ IDEA和Eclipse设置JVM运行参数

    打开 IDEA 安装目录,看到有一个 bin 目录,其中有两个 vmoptions 文件,需针对不同的JDK进行配置: 32 位:idea.exe.vmoptions64 位:idea64.exe.v ...

  4. C#的循环语句(四)

    一.while 循环(1).while 其实是for循环的变形写法for(int i = 1; i<=5;i++)  {循环体:} 上面的for循环可以写成int i= 1:for(;i< ...

  5. HDU 1698 Just a Hook 线段树区间更新、

    来谈谈自己对延迟标记(lazy标记)的理解吧. lazy标记的主要作用是尽可能的降低时间复杂度. 这样说吧. 如果你不用lazy标记,那么你对于一个区间更新的话是要对其所有的子区间都更新一次,但如果用 ...

  6. HOSt ip is not allowed to connect to this MySql server, MYSQL添加远程用户或允许远程访问三种方法

    HOSt ip is not allowed to connect to this MySql server 报错:1130-host ... is not allowed to connect to ...

  7. Python--day64--author表多对多关联book表

    数据库数据结构设计:

  8. js 键盘事件keyCode 总结

    开发中经常页面中的某些按钮或元素需要绑定到键盘的输入事件 keydown.keyup 事件 keydown 键盘按下触发事件 $("#btn").keydown(function( ...

  9. P1030 队列的基本操作

    题目描述 现在给你一个队列,它一开始是空的,你需要模拟队列的操作.队列的操作包括如下: "push x":将元素 x 放入队列中,其中x是一个int范围内的整数: "po ...

  10. ioctl 命令的实现

    ioctl 的 scull 实现只传递设备的配置参数, 并且象下面这样容易: switch(cmd) { case SCULL_IOCRESET: scull_quantum = SCULL_QUAN ...