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];
for(int i = 1 ; i <= n ; i++)
{
if( v[i - 1] > v[i] && v[i] < v[i + 1] )
dp[i] = 1;
dp[i] += dp[i - 1];
}
}
int max_towers(int L, int R, int D)
{
L++; R++;
int ans = dp[R] - dp[L - 1];
if( L == R )
return 1;
if( v[L - 1] < v[L] && v[L] < v[L + 1] )
ans++;
if( v[R - 1] > v[R] && v[R] > v[R + 1] )
ans++;
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... |