hdu 4908 BestCoder Sequence
올바른 방법: dp가 중위수의 위치에서 양쪽 dp로 우리는 이렇게 생각할 수 있다. 만약에 이 수가 중위수보다 크면 dp[i]=dp[i-1]+1, 그렇지 않으면 dp[i]=dp[i-1]-1을 얻을 수 있다. 그러면 우리는 중위수 양측의 dp값을 얻을 수 있다. 생각해 보면 첫 번째 분해: Lmax[i] R_min[i] 좌우 dp에서 0보다 작고 0보다 큰 개수를 기록한 다음에 같은 아래 표시된 곱하기 즉 Lmax[i]*R_min[i], 두 번째 부분의 해: 왼쪽에서 미드필더, 미드필더가 오른쪽, 양쪽을 함께 변수 l로 계산하고 r는 왼쪽과 오른쪽 dp가 0과 같은 개수를 기록하며 l+r+l*r+1;
dp[i]를 자세히 분석하면 i위치까지 중위수보다 크거나 중위수보다 작으면 대응하는 열의 개수를 나타낸다.
#include<iostream>
#include<math.h>
#include<stdio.h>
#include<algorithm>
#include<string.h>
#include<string>
#include<vector>
#include<queue>
#include<map>
#include<set>
#include<stack>
#define B(x) (1<<(x))
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
typedef unsigned ui;
const int oo = 0x3f3f3f3f;
//const ll OO = 0x3f3f3f3f3f3f3f3f;
const double eps = 1e-9;
#define lson rt<<1
#define rson rt<<1|1
void cmax(int& a, int b){ if (b > a)a = b; }
void cmin(int& a, int b){ if (b < a)a = b; }
void cmax(ll& a, ll b){ if (b > a)a = b; }
void cmin(ll& a, ll b){ if (b < a)a = b; }
void cmax(double& a, double b){ if (a - b < eps) a = b; }
void cmin(double& a, double b){ if (b - a < eps) a = b; }
void add(int& a, int b, int mod){ a = (a + b) % mod; }
void add(ll& a, ll b, ll mod){ a = (a + b) % mod; }
const ll MOD = 1000000007;
const int maxn = 110000;
int a[maxn];
int dp[maxn];
int L_min[maxn], L_max[maxn];
int R_min[maxn], R_max[maxn];
int main()
{
int n, mid, pos, l, r;
while (scanf("%d%d", &n, &mid) != EOF)
{
for (int i = 1; i <= n; i++)
{
scanf("%d", &a[i]);
if (a[i] == mid)
pos = i;
}
memset(L_min, 0, sizeof L_min);
memset(L_max, 0, sizeof L_max);
memset(R_min, 0, sizeof R_min);
memset(R_max, 0, sizeof R_max);
l = r = 0;
dp[pos] = 0;
for (int i = pos - 1; i >= 1; i--)
{
if (a[i] > mid)
dp[i] = dp[i + 1] + 1;
else
dp[i] = dp[i + 1] - 1;
if (dp[i] > 0)
L_max[dp[i]]++;
else if (dp[i] == 0)
l++;
else
L_min[-dp[i]]++;
}
for (int i = pos + 1; i <= n; i++)
{
if (a[i] > mid)
dp[i] = dp[i - 1] + 1;
else
dp[i] = dp[i - 1] - 1;
if (dp[i] > 0)
R_max[dp[i]]++;
else if (dp[i] == 0)
r++;
else
R_min[-dp[i]]++;
}
ll ans = l + r + l*r + 1;
for (int i = 1; i <= 40000; i++)
{
ans += (ll)L_min[i] * (ll)R_max[i];
ans += (ll)L_max[i] * (ll)R_min[i];
}
printf("%lld
", ans);
}
return 0;
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.