結果

問題 No.3301 Make Right Triangle
ユーザー tnakao0123
提出日時 2025-10-06 19:25:33
言語 C++17
(gcc 13.3.0 + boost 1.87.0)
結果
AC  
実行時間 42 ms / 2,000 ms
コード長 888 bytes
コンパイル時間 459 ms
コンパイル使用メモリ 41,176 KB
実行使用メモリ 7,716 KB
最終ジャッジ日時 2025-10-06 19:25:40
合計ジャッジ時間 6,968 ms
ジャッジサーバーID
(参考情報)
judge3 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 1
other AC * 9
権限があれば一括ダウンロードができます
コンパイルメッセージ
main.cpp: In function ‘int main()’:
main.cpp:26:8: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
   26 |   scanf("%d", &tn);
      |   ~~~~~^~~~~~~~~~~
main.cpp:30:10: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
   30 |     scanf("%d", &l);
      |     ~~~~~^~~~~~~~~~

ソースコード

diff #

/* -*- coding: utf-8 -*-
 *
 * 3301.cc:  No.3301 Make Right Triangle - yukicoder
 */

#include<cstdio>
#include<cassert>
#include<algorithm>

using namespace std;

/* constant */

/* typedef */

using ll = long long;

/* global variables */

/* subroutines */

/* main */

int main() {
  int tn;
  scanf("%d", &tn);

  while (tn--) {
    int l;
    scanf("%d", &l);

    // (m^2-n^2, 2mn, m^2+n^2)
    ll m, n;
    if (! (l & 1)) {
      // l=2mn
      m = l / 2, n = 1;
    }
    else {
      // l=m^2-n^2=(m+n)(m-n) ->m+n=l,m-n=1->m=(l+1)/2,n=(l-1)/2
       m = (l + 1) / 2, n = (l - 1) / 2;
    }

    ll mm = m * m, nn = n * n;
    ll a = mm - nn, b = 2 * m * n, c = mm + nn;
    printf("%lld %lld %lld\n", a, b, c);

    /*
    __int128 aa = (__int128)a * a;
    __int128 bb = (__int128)b * b;
    __int128 cc = (__int128)c * c;
    assert(aa + bb == cc);
    */
  }

  return 0;
}

0