제출 #678600

#제출 시각아이디문제언어결과실행 시간메모리
678600hotboy2703Dango Maker (JOI18_dango_maker)C++14
0 / 100
1 ms340 KiB
#include<bits/stdc++.h> using namespace std; int dp[3010][5]; pair <bool,bool> tmp[3010]; int n,m; int get(int x,int y){ if (x < 0)x = 0; if (y < 0)y = 0; if (x <= 0 && y <= 0)return 0; int res = -1;int r = x - y + 2; if (dp[x][r] != -1)return dp[x][r]; if (x <= 0){ res = get(x,y-1) + tmp[y].second; } else if (y <= 0){ res = get(x-1,y) + tmp[x].second; } else{ if (x >= y){ res = get(x-1,y); if (tmp[x].first){ res = max(res,1 + get(x-1,y-3)); } } else{ res = get(x,y-1); if (tmp[y].second){ res = max(res,1 + get(x-3,y-1)); } } } dp[x][r] = res; return res; } int solve(){ memset(dp,-1,sizeof dp); return get(n,n); } char a[3010][3010]; int main(){ ios_base::sync_with_stdio(0);cin.tie(nullptr);cout.tie(nullptr); cin>>n>>m; for (int i = 1;i <= n;i ++){ string s; cin>>s; for (int j = 1;j <= m;j ++){ a[i][j] = s[j-1]; } } int ans = 0; for (int k = 2;k <= n + m;k ++){ for (int i =1 ;i <= n;i ++){ int j = k - i; if (1 <= j && j <= m){ tmp[i].first = (a[i][j] == 'R' && a[i][j+1] == 'G' && a[i][j+2] == 'W'); tmp[i].second = (a[i][j] == 'R' && a[i+1][j] == 'G' && a[i+2][j] == 'W'); } else{ tmp[i] = {0,0}; } } ans += solve(); } cout<<ans<<'\n'; return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...