結果
問題 | No.55 正方形を描くだけの簡単なお仕事です。 |
ユーザー |
![]() |
提出日時 | 2015-05-17 20:40:25 |
言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 2 ms / 5,000 ms |
コード長 | 713 bytes |
コンパイル時間 | 459 ms |
コンパイル使用メモリ | 54,640 KB |
実行使用メモリ | 6,820 KB |
最終ジャッジ日時 | 2024-11-14 13:49:45 |
合計ジャッジ時間 | 1,202 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 21 |
ソースコード
#include <iostream> using namespace std; struct Point { int x; int y; }; int main() { Point p[3]; for (int i = 0; i < 3; ++i) { cin >> p[i].x >> p[i].y; } int n0; for (n0 = 0; n0 < 3; ++n0) { int n1 = (n0 + 1) % 3; int n2 = (n0 + 2) % 3; Point v1 = { p[n1].x - p[n0].x, p[n1].y - p[n0].y }; Point v2 = { p[n2].x - p[n0].x, p[n2].y - p[n0].y }; int dot = v1.x * v2.x + v1.y * v2.y; if (dot == 0) { int norm1 = v1.x * v1.x + v1.y * v1.y; int norm2 = v2.x * v2.x + v2.y * v2.y; if (norm1 == norm2) { Point p3 = { p[n0].x + v1.x + v2.x, p[n0].y + v1.y + v2.y }; cout << p3.x << " " << p3.y << endl; break; } } } if (n0 == 3) { cout << -1 << endl; } return 0; }