Yet Another Crosses Problem_被教育场(B题)_思维/经验_Educational Codeforces Round 68 [Rated for Div. 2]
B. Yet Another Crosses Problem
题目限制:
time limit per test2 seconds
memory limit per test256 megabytes
inputstandard input outputstandard output
主干:
You are given a picture consisting of n rows and m columns. Rows are numbered from 1 to n from the top to the bottom, columns are numbered from 1 to m from the left to the right. Each cell is painted either black or white.
You think that this picture is not interesting enough. You consider a picture to be interesting if there is at least one cross in it. A cross is represented by a pair of numbers x and y, where 1≤x≤n and 1≤y≤m, such that all cells in row x and all cells in column y are painted black.
For examples, each of these pictures contain crosses:
The fourth picture contains 4 crosses: at (1,3), (1,5), (3,3) and (3,5).
Following images don’t contain crosses:
You have a brush and a can of black paint, so you can make this picture interesting. Each minute you may choose a white cell and paint it black.
What is the minimum number of minutes you have to spend so the resulting picture contains at least one cross?
You are also asked to answer multiple independent queries.
Input
The first line contains an integer q (1≤q≤5⋅104) — the number of queries.
The first line of each query contains two integers n and m (1≤n,m≤5⋅104, n⋅m≤4⋅105) — the number of rows and the number of columns in the picture.
Each of the next n lines contains m characters — ‘.’ if the cell is painted white and ‘*’ if the cell is painted black.
It is guaranteed that ∑n≤5⋅104 and ∑n⋅m≤4⋅105.
Output
Print q lines, the i-th line should contain a single integer — the answer to the i-th query, which is the minimum number of minutes you have to spend so the resulting picture contains at least one cross.
Example
输入
9
5 5
..*..
..*..
*****
..*..
..*..
3 4
****
.*..
.*..
4 3
***
*..
*..
*..
5 5
*****
*.*.*
*****
..*.*
..***
1 4
****
5 5
.....
..*..
.***.
..*..
.....
5 3
...
.*.
.*.
***
.*.
3 3
.*.
*.*
.*.
4 4
*.**
....
*.**
*.**
输出
0
0
0
0
0
4
1
1
2
题目大意:
给你n*m大小的区域,满足填满区域的十字(就是说边上无空白),我们现在有刷子和一桶油漆,请问我们需要刷多少次才能够满足黑十字(上述条件),一次只能刷一格;
代码借鉴了,cf中的红名dalao,不得不说代码实在是太强了。
Mingrui Liu
想法:
记录每行/每列的空白数,在从中找出最小的,a[i] + b[j] - (s[i*m + j] == ‘.’),且用ans,与之前的不断对比,找出最小。
#include<iostream>
#include<math.h>
#include<cmath>
#include<algorithm>
#define rep(i,n) for(int i=0;i<n;++i)
using namespace std;
const int N = 4e5 + 5;
int T, n, m, a[N], b[N];
char s[N];
int main() {
for (cin >> T; T--;) {
cin >> n >> m;
rep(i, n)scanf("%s", s + i * m);
rep(i, n)a[i] = 0; rep(j, m)b[j] = 0;
rep(i, n)rep(j, m)if (s[i*m + j] == '.')++a[i], ++b[j];
//a[i]/b[j]分别用于记录行/列内的空白部分个数,在这其中找出最小的数。
int ans = 1e9 + 7;
rep(i, n)rep(j, m)ans = min(ans, a[i] + b[j] - (s[i*m + j] == '.'));
//这里是最重要的地方,找出最小,
//两点重合时(就是例如空白十字的中心)需要-1
printf("%d\n", ans);
}
return 0;
}
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步