Codeforces 2021 C Those Who Are With Us

Problem Discription\]\\color{blue}{\\texttt{\[Problem Discription\]}}\[Problem Discription

给定一个 n×mn \times mn×m 的表格 ai,ja_{i,j}ai,j,你可以恰好进行一次如下操作:

  1. 选择一个格点 (r,c)(r,c)(r,c)。
  2. 对于所有满足 i=ri=ri=r 或者 j=cj=cj=c 的格点 (i,j)(i,j)(i,j),使 ai,j←ai,j−1a_{i,j} \leftarrow a_{i,j}-1ai,j←ai,j−1。

求操作后所有格点最大值最小可能为多少。

多组数据,满足 1≤n×m≤1×1051 \leq n \times m \leq 1 \times 10^{5}1≤n×m≤1×105,且所有数据的 n×mn \times mn×m 的总和不超过 2×1052 \times 10^{5}2×105。

Analysis\]\\color{blue}{\\texttt{\[Analysis\]}}\[Analysis

记原来矩阵的最大值为 ttt,显然由于只能进行一次操作,且一次操作最多让一个格点的值减小 111,所以最终答案要么是 ttt,要么是 (t−1)(t-1)(t−1)。

思考哪些情况会让答案为 (t−1)(t-1)(t−1)。

显然,当所有取得最大值的格点要么分布在第 rrr 行要么分布在第 ccc 列时,我们可以通过一次操作 (r,c)(r,c)(r,c) 把所有最大值都干掉;否则答案为 ttt 不变。

统计每一行每一列有多少个最大值,分别记为 cntri,cntcj\text{cntr}{i},\text{cntc}{j}cntri,cntcj,显然第 iii 行和第 jjj 列的最大值的个数即为:

f(i,j)=cntri+cntcj−[ai,j=max⁡1≤i≤n,1≤j≤m{ai,j}]f(i,j)=\text{cntr}{i}+\text{cntc}{j}- \left [a_{i,j}=\max\limits_{1 \leq i \leq n, 1 \leq j \leq m} \{a_{i,j} \}\right ]f(i,j)=cntri+cntcj−[ai,j=1≤i≤n,1≤j≤mmax{ai,j}]

显然预先统计出最大值的个数 cnt\text{cnt}cnt,如果某个格点 (i,j)(i,j)(i,j) 满足 f(i,j)=cntf(i,j)=\text{cnt}f(i,j)=cnt,那么这个 (i,j)(i,j)(i,j) 就是我们需要的格点。

Code\color{blue}{\text{Code}}Code

cpp 复制代码
const int N=1e5+100;

int OneZDoubleY(){
	int n=read(),m=read();
	vector<int> a[n+2];
	for(int i=1;i<=n;i++){
		a[i].push_back(0);
		for(int j=1;j<=m;j++)
			a[i].push_back(read());
	}
	
	int maxn=a[1][1];
	for(int i=1;i<=n;i++)
		for(int j=1;j<=m;j++)
			ckmax(maxn,a[i][j]);
	
	int cnt=0;
	vector<int> cntr(n+1),cntc(m+1);
	for(int i=1;i<=n;i++)
		for(int j=1;j<=m;j++)
			if (a[i][j]==maxn){
				++cntr[i];
				++cntc[j];
				++cnt;
			}
	
	bool flag=false;
	for(int i=1;i<=n;i++)
		for(int j=1;j<=m;j++){
			int t=cntr[i]+cntc[j];
			if (a[i][j]==maxn) t--;
			
			if (t==cnt){
				flag=true;
				break;
			}
		}
	
	return printf("%d\n",flag?maxn-1:maxn);
}
//大家可以挑战一下不用 vector,用 malloc 来处理

int main(){
	int T=read();
	while (T--) OneZDoubleY();
	
	return 0;
}
相关推荐
蒹葭玉树21 分钟前
【C++上岸】C++常见面试题目--数据结构篇(第十七期)
数据结构·c++·面试
熊大与iOS39 分钟前
iOS 长截图的完美实现方案 - 附Demo源码
android·算法·ios
nonono42 分钟前
数据结构——树(04二叉树,二叉搜索树专项,代码练习)
数据结构
Elylicery42 分钟前
【职业】算法与数据结构专题
数据结构·算法
岁月静好20251 小时前
Leetcode二分查找(3)
算法·leetcode·职场和发展
一支鱼1 小时前
leetcode-4-寻找两个正序数组的中位数
算法·leetcode·typescript
Christo32 小时前
TSMC-1987《Convergence Theory for Fuzzy c-Means: Counterexamples and Repairs》
人工智能·算法·机器学习·kmeans
雷达学弱狗2 小时前
广度优先搜索(BFS, Breadth-First Search)
数据结构·算法·宽度优先
AndrewHZ2 小时前
【游戏开发】街景风格化运用到游戏中,一般有哪些风格可供选择?
算法·游戏·风格迁移·手游·风格化·游戏街景·k帧
桦说编程3 小时前
数据丢失,而且不抛出并发异常,多线程使用HashMap踩坑
java·数据结构·后端