洛谷 4251 [SCOI2015]小凸玩矩阵

【题解】
二分答案+二分图匹配。
先二分最小值Min,然后扫一遍这个矩阵,把满足a[i][j]<=Min的i,j连边,之后跑二分图匹配,如果最大匹配数大于等于n-k+1,当前的Min即是合法的。题目中要求选出的数不能在同一行或者同一列,而这种行与列连边跑二分图的做法就保证了一行与一列对应,最多只能选一次。题目中求第k大数的最小值,即有n-k+1个数小于等于Min,也就是最大匹配数大于等于n-k+1.
#include<cstdio>
#include<algorithm>
#include<cstring>
#define N 300
#define rg register
using namespace std;
int n,m,k,tmp,tot,T,last[N],a[N][N],p[N],v[N];
struct edge{
int to,pre;
}e[N*N];
inline int read(){
int k=,f=; char c=getchar();
while(c<''||c>'')c=='-'&&(f=-),c=getchar();
while(''<=c&&c<='')k=k*+c-'',c=getchar();
return k*f;
}
bool dfs(int x){
for(rg int i=last[x],to;i;i=e[i].pre) if(v[to=e[i].to]!=T){
v[to]=T;
if((!p[to])||dfs(p[to])){
p[to]=x; return ;
}
}
return ;
}
inline bool check(int x){
tmp=; tot=; T=;
for(rg int i=;i<=n;i++) last[i]=;
for(rg int i=;i<=m;i++) v[i]=,p[i]=;
for(rg int i=;i<=n;i++)
for(rg int j=;j<=m;j++) if(a[i][j]<=x){
e[++tot]=(edge){j,last[i]}; last[i]=tot;
}
for(rg int i=;i<=n;i++) ++T,tmp+=dfs(i);
return tmp>n-k;
}
int main(){
n=read(); m=read() ;k=read();
int l=2e9,r=;
for(rg int i=;i<=n;i++)
for(rg int j=;j<=m;j++){
a[i][j]=read();
l=min(l,a[i][j]);
r=max(r,a[i][j]);
}
while(l+<r){
int mid=(l+r)>>;
if(check(mid)) r=mid; else l=mid;
}
printf("%d\n",r);
return ;
}
洛谷 4251 [SCOI2015]小凸玩矩阵的更多相关文章
- [bzoj4443] [loj#2006] [洛谷P4251] [Scoi2015]小凸玩矩阵
		Description 小凸和小方是好朋友,小方给小凸一个 \(N \times M\)( \(N \leq M\) )的矩阵 \(A\) ,要求小秃从其中选出 \(N\) 个数,其中任意两个数字不能 ... 
- Luogu 4251 [SCOI2015]小凸玩矩阵
		BZOJ 4443 二分答案 + 二分图匹配 外层二分一个最小值,然后检验是否能选出$n - k + 1$个不小于当前二分出的$mid$的数.对于每一个$a_{i, j} \geq mid$,从$i$ ... 
- BZOJ_4443_[Scoi2015]小凸玩矩阵_二分+二分图匹配
		BZOJ_4443_[Scoi2015]小凸玩矩阵_二分+二分图匹配 Description 小凸和小方是好朋友,小方给小凸一个N*M(N<=M)的矩阵A,要求小秃从其中选出N个数,其中任意两个 ... 
- 2018.06.30 BZOJ4443: [Scoi2015]小凸玩矩阵(二分加二分图匹配)
		4443: [Scoi2015]小凸玩矩阵 Time Limit: 10 Sec Memory Limit: 128 MB Description 小凸和小方是好朋友,小方给小凸一个N*M(N< ... 
- BZOJ 4443: [Scoi2015]小凸玩矩阵 最大流
		4443: [Scoi2015]小凸玩矩阵 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=4443 Description 小凸和小方是好 ... 
- 【BZOJ4443】[Scoi2015]小凸玩矩阵 二分+二分图最大匹配
		[BZOJ4443][Scoi2015]小凸玩矩阵 Description 小凸和小方是好朋友,小方给小凸一个N*M(N<=M)的矩阵A,要求小秃从其中选出N个数,其中任意两个数字不能在同一行或 ... 
- bzoj 4443 [Scoi2015]小凸玩矩阵 网络流,二分
		[Scoi2015]小凸玩矩阵 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1564 Solved: 734[Submit][Status][Di ... 
- 【洛谷P4251】[SCOI2015]小凸玩矩阵(二分+二分图匹配)
		洛谷 题意: 给出一个\(n*m\)的矩阵\(A\).现要从中选出\(n\)个数,任意两个数不能在同一行或者同一列. 现在问选出的\(n\)个数中第\(k\)大的数的最小值是多少. 思路: 显然二分一 ... 
- 图论(网络流):[SCOI2015]小凸玩矩阵
		Description 小凸和小方是好朋友,小方给小凸一个N*M(N<=M)的矩阵A,要求小秃从其中选出N个数,其中任意两个数字不能在同一行或同一列,现小凸想知道选出来的N个数中第K大的数字的最 ... 
随机推荐
- 【410】Linux 系统 makefile 文件
			makefile 主要是用来合并编译文件 CC = gcc puzzle: puzzle.c boardADT.o $(CC) puzzle.c boardADT.o -o puzzle -lm bo ... 
- 【WIP】数据结构与算法入门
			创建: 2017/12/25 
- 17年day5
			/* 嗯,一切都快要结束了. 觉得不必要写太多,从day5开始就挺好吧. 记得去年这时候看到峰峰博客里的倒计时,心里还毫无波动,只是走的时候挺伤心. 现在轮到了我们. 峰峰我想你. 衷心祝zjk和my ... 
- robotframework - User key 操作
			一.用户关键字操作思路 a.创建model1资源 b.在model下创建用户关键字 - 循环 c.测试套件下创建test_case/case2 & 用户关键字 d.测试套件中导入Resourc ... 
- CF379F New Year Tree
			题意翻译 你是一个程序猿,现在有一棵新年树(并不是传统的带着叶子的树)--它有四个节点: 1,2,3,4. 其中2,3,4的父亲都是1. 新年里,程序猿们往往会做一些有趣的事情.你则选择以往这棵树上加 ... 
- fiddler不同代理模式的区别
			Fiddler有不同的代理模式,分为以下两种: 流模式(Streaming)和缓冲模式(Buffering). 流模式可以理解为一种实时通信的模式,有请求就有返回,也就是实时返回. 缓冲模式是等所有请 ... 
- SVN服务器搭建 内网可用外网不可用的问题
			检查1:内网端口映射到了外网端口,这样外网才能够访问到 映射的方式有两种: 1.通过路由器的虚拟服务器功能,网上一搜一大把. 2.将路由器的DMZ功能开启,并把DMZ主机设置为目标计算机. 检查2:S ... 
- IFormattable,ICustomFormatter, IFormatProvider接口
			定 义 1.IFormattable 提供一种功能,用以将对象的值格式化为字符串表示形式. 2.IFormatProvider 提供用于检索控制格式化的对象的机制 ... 
- 引入css的四种方式
			1.内联式引用:直接用在标签上,但维护成本高 style='font-size:16px;color:#000000' 2.外部连接式引用:css代码与html代码分离,便于代码重复使用 <li ... 
- MySQL 帮助类  MySQLHelper
			/// <summary> /// MySqlHelper操作类 /// </summary> public sealed partial class MySQLHelper ... 
