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 "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... |