結果
問題 | No.2331 Maximum Quadrilateral |
ユーザー |
![]() |
提出日時 | 2025-03-31 17:44:15 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 367 ms / 2,000 ms |
コード長 | 746 bytes |
コンパイル時間 | 209 ms |
コンパイル使用メモリ | 82,192 KB |
実行使用メモリ | 76,664 KB |
最終ジャッジ日時 | 2025-03-31 17:45:28 |
合計ジャッジ時間 | 8,590 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 45 |
ソースコード
n = int(input()) points = [tuple(map(int, input().split())) for _ in range(n)] max_area = 0 for i in range(n): ax, ay = points[i] for j in range(i + 1, n): bx, by = points[j] dx = bx - ax dy = by - ay current_max = -float('inf') current_min = float('inf') for k in range(n): if k == i or k == j: continue px, py = points[k] cross = (px - ax) * dy - (py - ay) * dx if cross > current_max: current_max = cross if cross < current_min: current_min = cross candidate = current_max - current_min if candidate > max_area: max_area = candidate print(max_area)