이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
#pragma GCC optimize("Ofast,unroll-loops,no-stack-protector,fast-math,inline")
#pragma GCC target("sse,sse2,sse3,ssse3,sse4,popcnt,lzcnt,mmx,abm,avx,avx2,fma")
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
typedef pair<int,int> pi;
typedef pair<long long,long long> pl;
#define all(s) s.begin(),s.end()
#define F first
#define S second
#define sz(a) a.size()
const ll mod = 1e9+7;
const ll INF = 1e18;
const int inf = 1e9+200;
const int maxn=3020;
int n,m;
ll ans=0;
char a[maxn][maxn];
int dp[3][maxn][maxn];
int H(int i,int j) {
return (a[i][j-1]=='R'&&a[i][j]=='G'&&a[i][j+1]=='W');
}
int V(int i,int j) {
return (a[i-1][j]=='R'&&a[i][j]=='G'&&a[i+1][j]=='W');
}
void solve() {
cin>>n>>m;
for(int i=1;i<=n;++i) {
for(int j=1;j<=m;++j) {
cin>>a[i][j];
}
}
for(int i=1;i<=n;++i) {
for(int j=1;j<=m;++j) {
dp[0][i][j]=max(dp[0][i-1][j+1],max(dp[1][i-1][j+1],dp[2][i-1][j+1]));
dp[1][i][j]=max(dp[0][i-1][j+1],dp[1][i-1][j+1]) + H(i,j);
dp[2][i][j]=max(dp[0][i-1][j+1],dp[2][i-1][j+1]) + V(i,j);
}
}
for(int i=1;i<=n;++i) {
ans+=(max(dp[0][i][1],max(dp[1][i][1],dp[2][i][1])));
}
for(int j=2;j<=m;++j) {
ans+=(max(dp[0][n][j],max(dp[1][n][j],dp[2][n][j])));
}
cout<<ans;
}
int main() {
ios_base::sync_with_stdio(0) , cin.tie(0) , cout.tie(0);
int T=1;
//cin>>T;
while(T--) {
solve();
}
return 0;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |