Untitled
unknown
c_cpp
a year ago
2.7 kB
3
Indexable
Never
#include "bits/stdc++.h" using namespace std; #ifdef LOCAL #include "debug.h" #else #define debug(x...) #endif using db = long double; constexpr db EPS = 1e-8; constexpr db PI = 3.1415926535; struct Point { int x, y; }; int len2(Point a, Point b) { return (a.x - b.x) * (a.x - b.x) + (a.y - b.y) * (a.y - b.y); } bool cw(Point a, Point b, Point c) { return a.x * (b.y - c.y) + b.x * (c.y - a.y) + c.x * (a.y - b.y) < 0; } bool ccw(Point a, Point b, Point c) { return a.x * (b.y - c.y) + b.x * (c.y - a.y) + c.x * (a.y - b.y) > 0; } void convex_hull(vector<Point> &a) { if (a.size() == 1) return; sort(a.begin(), a.end(), [&](Point lhs, Point rhs) { return lhs.x < rhs.x || (lhs.x == rhs.x && lhs.y < rhs.y); }); Point p1 = a[0], p2 = a.back(); vector<Point> up, down; up.push_back(p1); down.push_back(p1); for (size_t i = 1; i < a.size(); i++) { if (i == a.size() - 1 || cw(p1, a[i], p2)) { while (up.size() >= 2 && !cw(up[up.size() - 2], up[up.size() - 1], a[i])) { up.pop_back(); } up.push_back(a[i]); } if (i == a.size() - 1 || ccw(p1, a[i], p2)) { while (down.size() >= 2 && !ccw(down[down.size() - 2], down[down.size() - 1], a[i])) { down.pop_back(); } down.push_back(a[i]); } } a.clear(); for (size_t i = 0; i < up.size(); i++) { a.push_back(up[i]); } for (size_t i = down.size() - 2; i > 0; i--) { a.push_back(down[i]); } } void solve() { int n, xc, yc; cin >> n >> xc >> yc; vector<Point> pts(n); for (int i = 0; i < n; i++) { cin >> pts[i].x >> pts[i].y; } convex_hull(pts); n = pts.size(); int ans = 0; for (int i = 0; i < n; i++) { int x1 = pts[i].x, y1 = pts[i].y, x2 = pts[(i + 1) % n].x, y2 = pts[(i + 1) % n].y; int a = y2 - y1; int a_c = a * a; int b = x1 - x2; int b_c = b * b; int c = x2 * y1 - x1 * y2; int x = ((b_c * xc) - (a * b * yc) - (a * c)) / (a_c + b_c); int y = ((a_c * yc) - (a * b * xc) - (b * c)) / (a_c + b_c); debug(x1, y1, x2, y2, x, y); if (len2({x1, y1}, {x2, y2}) > len2({x1, y1}, {x, y}) && len2({x1, y1}, {x2, y2}) > len2({x2, y2}, {x, y})) { ans++; } } cout << ans; } signed main() { ios::sync_with_stdio(false); cin.tie(NULL); int tests = 1; // cin >> tests; while (tests--) { solve(); } return 0; }