This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
#define st first
#define nd second
#define mp make_pair
#define pb push_back
#define N 100005
using namespace std;
int n, m, grp, ans, b[N], a[N][60], u[N][60];
int o[] = {0, 0, 1, -1};
int p[] = {-1, 1, 0, 0};
char x;
void cikar(int grup){
for(int i = 1; i <= n; i++){
b[i] = 0;
for(int j = 1; j <= m; j++)
if(u[i][j - 1] != grup and u[i][j] == grup)
b[i]++;
}
}
void dfs(int i, int j){
u[i][j] = grp;
for(int k = 0; k < 4; k++)
if(a[i + o[k]][j + p[k]] and !u[i + o[k]][j + p[k]])
dfs(i + o[k], j + p[k]);
}
void bul(){
for(int i = 1; i <= n; i++){
int mn = b[i];
for(int j = i; j <= n; j++){
if(b[j])
mn = min(mn, b[j]);
ans += mn;
// cout << mn << endl;
}
}
}
int main() {
// freopen("in.txt", "r", stdin);
// freopen("out.txt", "w", stdout);
scanf("%d %d",&n ,&m);
for(int i = 1; i <= n; i++)
for(int j = 1; j <= m; j++){
scanf(" %c",&x);
if(x == '1')
a[i][j] = 1;
}
for(int i = 1; i <= n; i++)
for(int j = 1; j <= m; j++)
if(!u[i][j] and a[i][j]){
grp++;
dfs(i, j);
cikar(grp);
bul();
// for(int of = 1; of <= n; of++)cout << b[of] << " ";cout << endl;
}
printf("%d\n", ans);
return 0;
}
Compilation message (stderr)
raspad.cpp: In function 'int main()':
raspad.cpp:45:7: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
scanf("%d %d",&n ,&m);
~~~~~^~~~~~~~~~~~~~~~
raspad.cpp:48:9: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
scanf(" %c",&x);
~~~~~^~~~~~~~~~
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |