当前位置: 首页 > news >正文

CF2121C Those Who Are With Us

CF2121C Those Who Are With Us - 洛谷

题目描述
给定一个有 n 行 m 列的整数矩阵。第 i 行第 j 列的单元格包含数字 ai,j​。
你可以恰好进行一次如下操作:

  • 选择两个数 1≤r≤n 和 1≤c≤m。
  • 对于矩阵中所有满足 i=r 或 j=c 的单元格 (i,j),将 ai,j​ 减去 1。
    你需要在恰好进行一次这样的操作后,求出矩阵 a 中可能的最小最大值。

输入格式
每组测试数据包含多组测试用例。第一行包含一个整数 t(1≤t≤104),表示测试用例的数量。接下来是每个测试用例的描述。
每个测试用例的第一行包含两个整数 n 和 m(1≤n,m≤103),表示矩阵的行数和列数。
接下来的 n 行,每行包含 m 个整数 ai1​,ai2​,…,aim​(1≤aij​≤100),表示矩阵 a 的元素。
保证所有测试用例中 n⋅m 的总和不超过 2×105。

输出格式
对于每个测试用例,输出一次操作后矩阵 a 中的最小最大值。

输入输出样例
输入 #1
10
1 1
1
1 2
1
1 2
2 1
2
2 1
2 3
2 2
4 2
3 4
1 2 3 2
3 2 1 3
2 1 3 2
4 3
1 5 1
3 1 3
5 5 5
3 5 1
4 4
1 3 3 2
2 3 2 2
1 2 2 1
3 3 2 3
2 2
2 2
1 2
3 2
1 2
2 1
1 2
1 2
3 3
2 1 1
1 2 1
1 1 2

输出 #1
0
1
1
2
3
2
4
3
1
1

说明 / 提示
在前三个测试用例中,你可以选择 r=1 且 c=1。
在第四个测试用例中,你可以选择 r=1 且 c=2。
在第五个测试用例中,你可以选择 r=2 且 c=3。
在第六个测试用例中,你可以选择 r=3 且 c=2。
由 ChatGPT 4.1 翻译

思路:
找出最大值,计算每一行每一列的最大值个数,这样方便找出十字型内是否包含所有最大值。

代码:
 

#include <bits/stdc++.h>
using namespace std;
int main(void) {ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);int T;cin >> T;while (T--) {int n, m;cin >> n >> m;vector<vector<int>> a(n + 1, vector<int>(m + 1));int max_num = -1;// 第一步:找出最大值for (int i = 1; i <= n; ++i) {for (int j = 1; j <= m; ++j) {cin >> a[i][j];max_num = max(max_num, a[i][j]);}}// 第二步:统计每行、每列的最大值数量,以及总数量vector<int> row_count(n + 1, 0);  // 每行的最大值数量vector<int> col_count(m + 1, 0);  // 每列的最大值数量int total = 0;                    // 最大值的总数量for (int i = 1; i <= n; ++i) {for (int j = 1; j <= m; ++j) {if (a[i][j] == max_num){row_count[i]++;col_count[j]++;total++;}}}// 第三步:判断是否存在一个十字能包含所有最大值bool exists = false;for (int i = 1; i <= n; ++i) {for (int j = 1; j <= m; ++j) {// 当前位置是否是最大值(用于去重)int overlap = (a[i][j] == max_num) ? 1 : 0;// 十字包含的最大值数量 = 行数量 + 列数量 - 重复计算的当前位置if (row_count[i] + col_count[j] - overlap == total) {exists = true;break;}}if (exists) break;}// 输出结果if (exists) {cout << max_num - 1 << '\n';} else {cout << max_num << '\n';}}return 0;
}

http://www.lryc.cn/news/623878.html

相关文章:

  • 2001-2024年中国玉米种植分布数据集
  • 【牛客刷题】01字符串按递增长度截取并转换为十进制数值
  • Day07 缓存商品 购物车
  • 14.web api 5
  • LEA(Load Effective Address)指令
  • 19.5 「4步压缩大模型:GPTQ量化实战让OPT-1.3B显存直降75%」
  • 混沌工程(Chaos engineering):系统韧性保障之道
  • 图解希尔排序C语言实现
  • 【Java】多线程Thread类
  • 2025年- H97-Lc205--23.合并k个升序链表(链表、小根堆、优先队列)--Java版
  • 【撸靶笔记】第二关:GET -Error based -Intiger based
  • 【102页PPT】新一代数字化转型信息化总体规划方案(附下载方式)
  • 2.4 双向链表
  • 牛客周赛 Round 104(小红的矩阵不动点/小红的不动点权值)
  • 03高级语言逻辑结构到汇编语言之逻辑结构转换if (...) {...} else if {...} else {...}
  • react 错误边界
  • git stash临时保存工作区
  • Win11 文件资源管理器预览窗格显示 XAML 文件内容教程
  • 【牛客刷题】成绩统计与发短信问题详解
  • 【Git系列】如何从 Git 中删除 .idea 目录
  • 【线程安全(二) Java EE】
  • 寻找数组的中心索引
  • 如果用ApiFox调用Kubernetes API,需要怎么设置证书?
  • Day16 多任务(2)
  • USB-A 3.2 和 USB-A 2.0的区别
  • Day27 装饰器
  • 从零配置YOLOv8环境:RTX 3060显卡完整指南
  • AI评测的科学之道:当Benchmark遇上统计学
  • 48.Seata认识、部署TC服务、微服务集成
  • [Responsive theme color] 动态更新 | CSS变量+JS操控 | 移动端-汉堡菜单 | 实现平滑滚动