안녕하세요. 오늘은 가장 먼 두 점을 찾아볼 거예요.
https://www.acmicpc.net/problem/10254
이걸 응용하면 풀 수 있습니다.
#include <iostream>
#include <vector>
#include <algorithm>
#include <cmath>
#define ll long long
#define pii pair <ll,ll>
using namespace std;
ll CCW(pii A, pii B, pii C)
{
ll ax = A.first, ay = A.second, bx = B.first, by = B.second, cx = C.first, cy = C.second;
ll ccw = ax * (by - cy) + bx * (cy - ay) + cx * (ay - by);
if (ccw < 0) return -1;
if (ccw == 0) return 0;
return 1;
}
ll dist(pii A, pii B)
{
return (A.first - B.first) * (A.first - B.first) + (A.second - B.second) * (A.second - B.second);
}
bool ycmp(pii A, pii B)
{
if (A.second != B.second) return A.second < B.second;
return A.first < B.first;
}
pii low_dot;
bool cmp(pii A, pii B)
{
if (CCW(low_dot, A, B) > 0) return 1;
if (CCW(low_dot, A, B) == 0) return dist(low_dot, A) < dist(low_dot, B);
return 0;
}
ll stk[202020] = { 0 }, top = 2;
vector <pii> make_convex(vector <pii> v)
{
top = 2;
ll N = v.size();
sort(v.begin(), v.end(), ycmp);
low_dot = v[0];
sort(v.begin() + 1, v.end(), cmp);
stk[0] = 0; stk[1] = 1;
for (int i = 2; i < N; i++)
{
while (top >= 2 && CCW(v[i], v[stk[top - 2]], v[stk[top - 1]]) <= 0)
top--;
stk[top++] = i;
}
vector <pii> ans;
for (int i = 0; i < top; i++)
ans.push_back(v[stk[i]]);
return ans;
}
pair <pii, pii> RoCal(vector <pii> v)
{
ll N = v.size();
ll mx = 0;
pii ans1, ans2;
ll i, next_i, j = 0, next_j;
for (i = 0; i < N; i++)
{
next_i = (i + 1) % N;
while (true)
{
if (mx < dist(v[i], v[j]))
{
mx = dist(v[i], v[j]);
ans1 = v[i];
ans2 = v[j];
}
next_j = (j + 1) % N;
pii v1, v2;
v1.first = v[i].first - v[next_i].first;
v1.second = v[i].second - v[next_i].second;
v2.first = v[j].first - v[next_j].first;
v2.second = v[j].second - v[next_j].second;
if (CCW({ 0,0 }, v1, v2) > 0)
j = next_j;
else
break;
}
if (mx < dist(v[i], v[j]))
{
mx = dist(v[i], v[j]);
ans1 = v[i];
ans2 = v[j];
}
}
return { ans1,ans2 };
}
int main(void)
{
ios_base::sync_with_stdio(false); cin.tie(NULL);
ll T, N, i, a, b;
cin >> T;
while (T--)
{
vector <pii> v;
cin >> N;
for (i = 0; i < N; i++)
{
cin >> a >> b;
v.push_back({ a,b });
}
pair <pii, pii> ans = RoCal(make_convex(v));
cout << ans.first.first << ' ' << ans.first.second << ' ' << ans.second.first << ' ' << ans.second.second << "\n";
}
}
감사합니다.