题解:CF2121C Those Who Are With Us
给定一个
- 选择一个格点
(r,c) 。 - 对于所有满足
i=r 或者j=c 的格点(i,j) ,使a_{i,j} \leftarrow a_{i,j}-1 。
求操作后所有格点最大值最小可能为多少。
多组数据,满足
记原来矩阵的最大值为
思考哪些情况会让答案为
显然,当所有取得最大值的格点要么分布在第
统计每一行每一列有多少个最大值,分别记为
显然预先统计出最大值的个数
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;
}