제출 #126017

#제출 시각아이디문제언어결과실행 시간메모리
126017zeyad49Mountains (IOI17_mountains)C++17
0 / 100
2 ms376 KiB
#include "mountains.h" #define x first #define y second using namespace std; typedef pair<int,int> point; const int MAX = 2005; int dp[MAX][MAX]; point p[MAX]; long long ccw(point a, point b, point c) { return (b.x - a.x) * (c.y - a.y) - (b.y - a.y) * (c.x - a.x); } int maximum_deevs(vector<int> y) { int n = y.size(); for (int i = 0; i < n; i++) { p[i].y = y[i]; p[i].x = i; } for (int r = 1; r <= n; r++) { int sum = 0, last = r - 1; dp[r - 1][r] = 1; for (int l = r - 2; l >= 0; l--) { dp[l][r] = dp[l][r - 1]; if (ccw(p[l], p[last], p[r - 1]) >= 0) { sum += dp[l + 1][last]; last = l; } dp[l][r] = max(dp[l][r], 1 + sum + dp[l][last]); } } return dp[0][n]; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...