#include<bits/stdc++.h>
using namespace std;
typedef long long int lld;
typedef pair<lld,lld> pii;
#define rep(i,a,b) for(int i=a;i<b;i++)
#define trav(a,v) for(auto a:v)
int has[3000][3000][2];
int n,m;
bool valid(int x, int y){
if(x>=0 && x<n && y>=0 && y<m)return true;
return false;
}
bool visited[1000000];
int size;
int independent;
vector<int> graph[1000000];
queue<int> q;
vector<int> tree[1000000];
int DP[1000000][2];
void DFS(int node){
visited[node]=true;
//q.push(node);
trav(v,graph[node]){
if(!visited[v]){
tree[node].push_back(v);
DFS(v);
}
}
}
int compute(int node, int x){
if(DP[node][x]!=-1)return DP[node][x];
DP[node][x]=0;
if(x==0){
trav(v,tree[node]){
DP[node][x]+=max(compute(v,0),compute(v,1));
}
return DP[node][x];
}
DP[node][x]++;
trav(v,tree[node]){
DP[node][x]+=compute(v,0);
}
return DP[node][x];
}
int main(){
cin>>n>>m;
string table[n];
rep(i,0,n){
cin>>table[i];
}
int V=0;
int H=0;
vector<pii> v;
vector<pii> h;
rep(i,0,n){
rep(j,0,m){
has[i][j][0]=-1;
has[i][j][1]=-1;
if(table[i][j]=='R'){
if(i+2<n && table[i+1][j]=='G' && table[i+2][j]=='W'){
has[i][j][0]=V;
V++;
v.push_back(pii(i,j));
}
if(j+2<m && table[i][j+1]=='G' && table[i][j+2]=='W'){
has[i][j][1]=H;
H++;
h.push_back(pii(i,j));
}
}
}
}
rep(i,0,n){
rep(j,0,m){
if(has[i][j][0]!=-1){
if(has[i][j][1]!=-1){
graph[has[i][j][0]].push_back(has[i][j][1]+V);
graph[has[i][j][1]+V].push_back(has[i][j][0]);
}
if(valid(i+1,j-1) && has[i+1][j-1][1]!=-1){
graph[has[i][j][0]].push_back(has[i+1][j-1][1]+V);
graph[has[i+1][j-1][1]+V].push_back(has[i][j][0]);
}
if(valid(i+2,j-2) && has[i+2][j-2][1]!=-1){
graph[has[i][j][0]].push_back(has[i+2][j-2][1]+V);
graph[has[i+2][j-2][1]+V].push_back(has[i][j][0]);
}
}
}
}
//cout<<V+H<<endl;
rep(i,0,V+H){
DP[i][0]=-1;
DP[i][1]=-1;
/*trav(v,graph[i]){
cout<<v<<" ";
}
cout<<endl;*/
}
rep(i,0,V+H){
visited[i]=false;
}
int ans=0;
rep(i,0,V+H){
if(!visited[i]){
DFS(i);
/*while(!q.empty()){
//if(q.front()<V)cout<<v[q.front()].first<<","<<v[q.front()].second<<" ";
//if(q.front()>=V)cout<<h[q.front()-V].first<<","<<h[q.front()-V].second<<" ";
visited[q.front()]=false;
q.pop();
}//cout<<endl;*/
ans+=max(compute(i,0),compute(i,1));
//cout<<independent<<" "<<size-independent<<"A"<<endl;
}
}
/*rep(i,0,V+H){
cout<<compute(i,0)<<" "<<compute(i,1)<<endl;
}*/
cout<<ans<<endl;
return 0;
}
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
45 ms |
47352 KB |
Output is correct |
2 |
Correct |
45 ms |
47352 KB |
Output is correct |
3 |
Correct |
46 ms |
47356 KB |
Output is correct |
4 |
Correct |
45 ms |
47352 KB |
Output is correct |
5 |
Correct |
45 ms |
47352 KB |
Output is correct |
6 |
Correct |
45 ms |
47352 KB |
Output is correct |
7 |
Correct |
46 ms |
47352 KB |
Output is correct |
8 |
Correct |
46 ms |
47248 KB |
Output is correct |
9 |
Correct |
45 ms |
47352 KB |
Output is correct |
10 |
Correct |
45 ms |
47352 KB |
Output is correct |
11 |
Correct |
46 ms |
47352 KB |
Output is correct |
12 |
Correct |
45 ms |
47340 KB |
Output is correct |
13 |
Correct |
46 ms |
47352 KB |
Output is correct |
14 |
Correct |
45 ms |
47352 KB |
Output is correct |
15 |
Correct |
45 ms |
47352 KB |
Output is correct |
16 |
Correct |
45 ms |
47480 KB |
Output is correct |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
45 ms |
47352 KB |
Output is correct |
2 |
Correct |
45 ms |
47352 KB |
Output is correct |
3 |
Correct |
46 ms |
47356 KB |
Output is correct |
4 |
Correct |
45 ms |
47352 KB |
Output is correct |
5 |
Correct |
45 ms |
47352 KB |
Output is correct |
6 |
Correct |
45 ms |
47352 KB |
Output is correct |
7 |
Correct |
46 ms |
47352 KB |
Output is correct |
8 |
Correct |
46 ms |
47248 KB |
Output is correct |
9 |
Correct |
45 ms |
47352 KB |
Output is correct |
10 |
Correct |
45 ms |
47352 KB |
Output is correct |
11 |
Correct |
46 ms |
47352 KB |
Output is correct |
12 |
Correct |
45 ms |
47340 KB |
Output is correct |
13 |
Correct |
46 ms |
47352 KB |
Output is correct |
14 |
Correct |
45 ms |
47352 KB |
Output is correct |
15 |
Correct |
45 ms |
47352 KB |
Output is correct |
16 |
Correct |
45 ms |
47480 KB |
Output is correct |
17 |
Correct |
45 ms |
47356 KB |
Output is correct |
18 |
Correct |
45 ms |
47364 KB |
Output is correct |
19 |
Correct |
47 ms |
47352 KB |
Output is correct |
20 |
Correct |
45 ms |
47368 KB |
Output is correct |
21 |
Correct |
44 ms |
47352 KB |
Output is correct |
22 |
Correct |
45 ms |
47352 KB |
Output is correct |
23 |
Correct |
45 ms |
47352 KB |
Output is correct |
24 |
Correct |
47 ms |
47352 KB |
Output is correct |
25 |
Correct |
54 ms |
47352 KB |
Output is correct |
26 |
Correct |
55 ms |
47352 KB |
Output is correct |
27 |
Correct |
45 ms |
47352 KB |
Output is correct |
28 |
Correct |
46 ms |
47324 KB |
Output is correct |
29 |
Correct |
45 ms |
47352 KB |
Output is correct |
30 |
Correct |
45 ms |
47352 KB |
Output is correct |
31 |
Correct |
46 ms |
47380 KB |
Output is correct |
32 |
Correct |
45 ms |
47352 KB |
Output is correct |
33 |
Correct |
45 ms |
47288 KB |
Output is correct |
34 |
Correct |
53 ms |
47392 KB |
Output is correct |
35 |
Correct |
62 ms |
47352 KB |
Output is correct |
36 |
Correct |
46 ms |
47356 KB |
Output is correct |
37 |
Correct |
48 ms |
47352 KB |
Output is correct |
38 |
Correct |
46 ms |
47356 KB |
Output is correct |
39 |
Correct |
46 ms |
47324 KB |
Output is correct |
40 |
Correct |
45 ms |
47352 KB |
Output is correct |
41 |
Correct |
46 ms |
47480 KB |
Output is correct |
42 |
Correct |
45 ms |
47352 KB |
Output is correct |
43 |
Correct |
45 ms |
47352 KB |
Output is correct |
44 |
Correct |
45 ms |
47324 KB |
Output is correct |
45 |
Correct |
45 ms |
47352 KB |
Output is correct |
46 |
Correct |
45 ms |
47320 KB |
Output is correct |
47 |
Correct |
45 ms |
47356 KB |
Output is correct |
48 |
Correct |
46 ms |
47352 KB |
Output is correct |
49 |
Correct |
45 ms |
47352 KB |
Output is correct |
50 |
Correct |
46 ms |
47328 KB |
Output is correct |
51 |
Correct |
45 ms |
47352 KB |
Output is correct |
52 |
Correct |
46 ms |
47352 KB |
Output is correct |
53 |
Correct |
45 ms |
47352 KB |
Output is correct |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
45 ms |
47352 KB |
Output is correct |
2 |
Correct |
45 ms |
47352 KB |
Output is correct |
3 |
Correct |
46 ms |
47356 KB |
Output is correct |
4 |
Correct |
45 ms |
47352 KB |
Output is correct |
5 |
Correct |
45 ms |
47352 KB |
Output is correct |
6 |
Correct |
45 ms |
47352 KB |
Output is correct |
7 |
Correct |
46 ms |
47352 KB |
Output is correct |
8 |
Correct |
46 ms |
47248 KB |
Output is correct |
9 |
Correct |
45 ms |
47352 KB |
Output is correct |
10 |
Correct |
45 ms |
47352 KB |
Output is correct |
11 |
Correct |
46 ms |
47352 KB |
Output is correct |
12 |
Correct |
45 ms |
47340 KB |
Output is correct |
13 |
Correct |
46 ms |
47352 KB |
Output is correct |
14 |
Correct |
45 ms |
47352 KB |
Output is correct |
15 |
Correct |
45 ms |
47352 KB |
Output is correct |
16 |
Correct |
45 ms |
47480 KB |
Output is correct |
17 |
Correct |
45 ms |
47356 KB |
Output is correct |
18 |
Correct |
45 ms |
47364 KB |
Output is correct |
19 |
Correct |
47 ms |
47352 KB |
Output is correct |
20 |
Correct |
45 ms |
47368 KB |
Output is correct |
21 |
Correct |
44 ms |
47352 KB |
Output is correct |
22 |
Correct |
45 ms |
47352 KB |
Output is correct |
23 |
Correct |
45 ms |
47352 KB |
Output is correct |
24 |
Correct |
47 ms |
47352 KB |
Output is correct |
25 |
Correct |
54 ms |
47352 KB |
Output is correct |
26 |
Correct |
55 ms |
47352 KB |
Output is correct |
27 |
Correct |
45 ms |
47352 KB |
Output is correct |
28 |
Correct |
46 ms |
47324 KB |
Output is correct |
29 |
Correct |
45 ms |
47352 KB |
Output is correct |
30 |
Correct |
45 ms |
47352 KB |
Output is correct |
31 |
Correct |
46 ms |
47380 KB |
Output is correct |
32 |
Correct |
45 ms |
47352 KB |
Output is correct |
33 |
Correct |
45 ms |
47288 KB |
Output is correct |
34 |
Correct |
53 ms |
47392 KB |
Output is correct |
35 |
Correct |
62 ms |
47352 KB |
Output is correct |
36 |
Correct |
46 ms |
47356 KB |
Output is correct |
37 |
Correct |
48 ms |
47352 KB |
Output is correct |
38 |
Correct |
46 ms |
47356 KB |
Output is correct |
39 |
Correct |
46 ms |
47324 KB |
Output is correct |
40 |
Correct |
45 ms |
47352 KB |
Output is correct |
41 |
Correct |
46 ms |
47480 KB |
Output is correct |
42 |
Correct |
45 ms |
47352 KB |
Output is correct |
43 |
Correct |
45 ms |
47352 KB |
Output is correct |
44 |
Correct |
45 ms |
47324 KB |
Output is correct |
45 |
Correct |
45 ms |
47352 KB |
Output is correct |
46 |
Correct |
45 ms |
47320 KB |
Output is correct |
47 |
Correct |
45 ms |
47356 KB |
Output is correct |
48 |
Correct |
46 ms |
47352 KB |
Output is correct |
49 |
Correct |
45 ms |
47352 KB |
Output is correct |
50 |
Correct |
46 ms |
47328 KB |
Output is correct |
51 |
Correct |
45 ms |
47352 KB |
Output is correct |
52 |
Correct |
46 ms |
47352 KB |
Output is correct |
53 |
Correct |
45 ms |
47352 KB |
Output is correct |
54 |
Correct |
46 ms |
47352 KB |
Output is correct |
55 |
Correct |
55 ms |
59560 KB |
Output is correct |
56 |
Correct |
46 ms |
47608 KB |
Output is correct |
57 |
Correct |
54 ms |
55640 KB |
Output is correct |
58 |
Correct |
135 ms |
64684 KB |
Output is correct |
59 |
Correct |
812 ms |
155676 KB |
Output is correct |
60 |
Correct |
809 ms |
155716 KB |
Output is correct |
61 |
Correct |
811 ms |
155688 KB |
Output is correct |
62 |
Correct |
45 ms |
47352 KB |
Output is correct |
63 |
Correct |
804 ms |
154908 KB |
Output is correct |
64 |
Runtime error |
1200 ms |
262144 KB |
Execution killed with signal 11 (could be triggered by violating memory limits) |
65 |
Halted |
0 ms |
0 KB |
- |