結果

問題 No.55 正方形を描くだけの簡単なお仕事です。
ユーザー HimatsubushinHimatsubushin
提出日時 2022-03-09 08:28:15
言語 C
(gcc 12.3.0)
結果
WA  
実行時間 -
コード長 1,145 bytes
コンパイル時間 291 ms
コンパイル使用メモリ 31,024 KB
実行使用メモリ 4,476 KB
最終ジャッジ日時 2023-10-11 07:01:10
合計ジャッジ時間 1,420 ms
ジャッジサーバーID
(参考情報)
judge15 / judge14
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 WA -
testcase_01 WA -
testcase_02 WA -
testcase_03 WA -
testcase_04 WA -
testcase_05 WA -
testcase_06 WA -
testcase_07 WA -
testcase_08 WA -
testcase_09 WA -
testcase_10 WA -
testcase_11 WA -
testcase_12 WA -
testcase_13 WA -
testcase_14 WA -
testcase_15 WA -
testcase_16 WA -
testcase_17 WA -
testcase_18 WA -
testcase_19 WA -
testcase_20 WA -
testcase_21 WA -
testcase_22 WA -
testcase_23 WA -
testcase_24 WA -
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <stdio.h>
#include <stdlib.h>
#include <math.h>


int main(void) {
  int i, a, b, f = 0;
  double ra[3], rb[3], l[3], x, y;
  
  for (i = 0; i < 3; i++) {
    scanf("%d %d", &a, &b);
    ra[i] = (double)a;
    rb[i] = (double)b;
  }

  for (i = 0; i < 3; i++)
    l[i] = sqrt(pow(ra[i] - ra[(i + 1) % 3], 2.0) + pow(rb[i] - rb[(i + 1) % 3], 2.0));

  x = y = 0.0;
  for (i = 0; i < 3; i++) {
    printf("%lf %lf %lf %lf\n", l[i], l[(i + 1) % 3],  pow(l[(i + 1) % 3], 2.0) + pow(l[(i + 1) % 3], 2.0), pow(l[(i + 2) % 3], 2.0));
    if (fabs(l[i] - l[(i + 1) % 3]) <= 1e-6 && fabs(pow(l[i], 2.0) + pow(l[(i + 1) % 3], 2.0) - pow(l[(i + 2) % 3], 2.0)) <= 1e-6) {
      switch (i) {
        case 0:
          x = ra[0] - ra[1] + ra[2];
          y = rb[0] - rb[1] + rb[2];
          break;
        case 1:
          x = ra[0] + ra[1] - ra[2];
          y = rb[0] + rb[1] - rb[2];
          break;
        case 2:
          x = -ra[0] + ra[1] + ra[2];
          y = -rb[0] + rb[1] + rb[2];
          break;
      }
      f = 1;
    }
  }

  if (f == 1)
    printf("%d %d", (int)x, (int)y);
  else
    printf("-1");

  return EXIT_SUCCESS;
}
0