【LOJ】#2006. 「SCOI2015」小凸玩矩阵
题解
又是美好的一天,我今天的小目标是LOJ刷题数名次前进两名(虽然巨佬们都是BZOJ千题啊这样的><,我就在LOJ划划水吧,我永远喜欢LOJ
这道题要求K大值最小,又是什么什么大值最小,这已经很暗示了,因为K大值和K小值显然等价,怎么不说小值最小?就是暗示你二分嘛
那我们就在值域上二分一个K大值 t,然后在矩阵里把所有小于等于t的数改成0,所有大于t的数改成1,我们只要能选N - K + 1个0出来,我们就可以判断真正的K大值最小解一定小于等于t
这个可以行列拆点跑二分图匹配
复杂度\(O(nm \log V)\)
代码
#include <bits/stdc++.h>
#define MAXN 50005
//#define ivorysi
#define enter putchar('\n')
#define space putchar(' ')
#define fi first
#define se second
using namespace std;
typedef long long int64;
typedef double db;
template<class T>
void read(T &res) {
    res = 0;char c = getchar();T f = 1;
    while(c < '0' || c > '9') {
	if(c == '-') f = -1;
	c = getchar();
    }
    while(c >= '0' && c <= '9') {
	res = res * 10 + c - '0';
	c = getchar();
    }
    res *= f;
}
template<class T>
void out(T x) {
    if(x < 0) {putchar('-');x = -x;}
    if(x >= 10) {
	out(x / 10);
    }
    putchar('0' + x % 10);
}
int N,M,K,L,R;
int a[255][255];
struct node {
    int to,next;
}E[200005];
int head[505],sumE,mat[505];
bool vis[505];
void add(int u,int v) {
    E[++sumE].to = v;
    E[sumE].next = head[u];
    head[u] = sumE;
}
void Init() {
    read(N);read(M);read(K);
    L = 0x7fffffff,R = 0;
    for(int i = 1 ; i <= N ; ++i) {
	for(int j = 1 ; j <= M ; ++j) {
	    read(a[i][j]);
	    R = max(R,a[i][j]);
	    L = min(L,a[i][j]);
	}
    }
}
bool match(int u) {
    for(int i = head[u] ; i ; i = E[i].next) {
	int v = E[i].to;
	if(!vis[v]) {
	    vis[v] = 1;
	    if(!mat[v] || match(mat[v])) {
		mat[v] = u;
		return true;
	    }
	}
    }
    return false;
}
int calc(int MID) {
    sumE = 0;memset(head,0,sizeof(head));
    for(int i = 1 ; i <= N ; ++i) {
	for(int j = 1 ; j <= M ; ++j) {
	    if(a[i][j] <= MID) add(i,j + N),add(j + N,i);
	}
    }
    int res = 0;
    memset(mat,0,sizeof(mat));
    for(int i = 1 ; i <= N ; ++i) {
	memset(vis,0,sizeof(vis));
	if(match(i)) ++res;
    }
    return res;
}
void Solve() {
    Init();
    while(L < R) {
	int mid = (L + R) >> 1;
	if(calc(mid) >= N - K + 1) R = mid;
	else L = mid + 1;
    }
    out(L);enter;
}
int main() {
#ifdef ivorysi
    freopen("f1.in","r",stdin);
#endif
    Solve();
    return 0;
}
【LOJ】#2006. 「SCOI2015」小凸玩矩阵的更多相关文章
- loj #2006. 「SCOI2015」小凸玩矩阵
		#2006. 「SCOI2015」小凸玩矩阵 题目描述 小凸和小方是好朋友,小方给小凸一个 N×M N \times MN×M(N≤M N \leq MN≤M)的矩阵 A AA,要求小凸从其中选出 ... 
- LibreOJ #2006. 「SCOI2015」小凸玩矩阵 二分答案+二分匹配
		#2006. 「SCOI2015」小凸玩矩阵 内存限制:256 MiB时间限制:1000 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: 匿名 提交提交记录统计讨论测试数据 题目描述 ... 
- LibreOJ #2006. 「SCOI2015」小凸玩矩阵
		想了挺久没想出来,一看题解恍然大悟.一个数对应一行和一列,二分答案,凡是小于等于答案的就连边.如果满足能够取出 \(n - k + 1\) 个不比二分中点 \(mid\) 大的数,那么r = mid, ... 
- loj#2009.「SCOI2015」小凸玩密室
		题目链接 loj#2009. 「SCOI2015」小凸玩密室 题解 树高不会很高<=20 点亮灯泡x,点亮x的一个子树,再点亮x另外的子树, 然后回到x的父节点,点亮父节点之后再点亮父节点的其他 ... 
- AC日记——「SCOI2015」小凸玩矩阵 LiBreOJ 2006
		「SCOI2015」小凸玩矩阵 思路: 二分+最大流: 代码: #include <bits/stdc++.h> using namespace std; #define maxn 300 ... 
- 「SCOI2015」小凸玩矩阵 解题报告
		「SCOI2015」小凸玩矩阵 我好沙茶啊 把点当边连接行和列,在外面二分答案跑图的匹配就行了 我最开始二分方向搞反了,样例没过. 脑袋一抽,这绝壁要费用流,连忙打了个KM 然后wa了,一想这个不是完 ... 
- 「SCOI2015」小凸玩矩阵
		题目链接 问题分析 题目给了充足的暗示,我们只需要二分答案然后跑匈牙利即可.要相信匈牙利的速度 参考程序 #include <bits/stdc++.h> using namespace ... 
- 「SCOI2015」小凸玩密室 解题报告
		「SCOI2015」小凸玩密室 虽然有心里在想一些奇奇怪怪的事情的原因,不过还是写太久了.. 不过这个题本身也挺厉害的 注意第一个被点亮的是任意选的,我最开始压根没注意到 \(dp_{i,j}\)代表 ... 
- —Libre#2009. 「SCOI2015」小凸玩密室
		#2009. 「SCOI2015」小凸玩密室 内存限制:256 MiB时间限制:1000 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: 匿名 提交提交记录统计讨论测试数据 题目描述 ... 
随机推荐
- SP1487 PT07J - Query on a tree III (主席树)
			SP1487 PT07J - Query on a tree III 题意翻译 你被给定一棵带点权的n个点的有根数,点从1到n编号. 定义查询 query(x,k): 寻找以x为根的k大点的编号(从小 ... 
- jdk1.5后枚举类的定义规则
			转: http://blog.csdn.net/willcold/article/details/12844487 JDK1.5 新增的enum关键字用于定义枚举类 枚举类也 ... 
- IO多路复用之epoll(二)
			前一篇介绍了epoll的LT模式,LT模式注意epollout事件在数据全部写成功后需要取消关注, 或者更改为EPOLLIN. 而这次epoll的ET模式,要注意的是在读和写的过程中要在循环中写完或者 ... 
- 题解【bzoj3240 [NOI2013]矩阵游戏】
			挖坑2333 等我把代码写完了再写 
- bzoj 1528 [POI2005]sam-Toy Cars 堆维护+贪心
			1528: [POI2005]sam-Toy Cars Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 716 Solved: 306[Submit][S ... 
- 数学:随机素数测试(Miller_Rabin算法)和求整数素因子(Pollard_rho算法)
			POJ1811 给一个大数,判断是否是素数,如果不是素数,打印出它的最小质因数 随机素数测试(Miller_Rabin算法) 求整数素因子(Pollard_rho算法) 科技题 #include< ... 
- (三)配置Hadoop1.2.1+eclipse(Juno版)开发环境,并运行WordCount程序
			配置Hadoop1.2.1+eclipse(Juno版)开发环境,并运行WordCount程序 一. 需求部分 在ubuntu上用Eclipse IDE进行hadoop相关的开发,需要在Eclip ... 
- 【BZOJ】2331: [SCOI2011]地板 插头DP
			[题意]给定n*m的地板,有一些障碍格,要求用L型的方块不重不漏填满的方案数.L型方块是从一个方格向任意两个相邻方向延伸的方块,不能不延伸.n*m<=100. [算法]插头DP [题解]状态0表 ... 
- 【BZOJ】1901: Zju2112 Dynamic Rankings
			[题意]带修改的查询区间第k小 [算法]树状数组套可持久化线段树 [题解]对于树状数组上的每个节点,维护可持久化权值线段树(节点为权值),从而达到查询前缀和的目的. 对于每次修改,在待修改线段树基础上 ... 
- c++都忘记了,看了看那本发黄的C++primer,还是要去翻下了
			char *s="string"和char s[]="string"的区别 void main() { char* pStr1 = "Hello!&q ... 
