이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "towers.h"
#include <bits/stdc++.h>
using namespace std;
const int maxn = 100010;
int n;
int v[maxn];
int dp[maxn];
void init(int N, std::vector<int> H) {
n = N;
for(int i = 1 ; i <= n ; i++)
v[i] = H[i - 1];
}
int max_towers(int L, int R, int D)
{
L++; R++;
int ans = 0;
for(int i = R ; i >= L ; i--)
{
dp[i] = 0;
int maxTower = v[i + 1];
for(int j = i + 2 ; j <= R ; j++)
{
if( v[i] <= maxTower - D && v[j] <= maxTower - D )
dp[i] = max( dp[i] , dp[j] );
maxTower = max( maxTower , v[j] );
}
dp[i]++;
ans = max( ans , dp[i] );
}
return ans;
}
# | 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... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |