結果
問題 | No.781 円周上の格子点の数え上げ |
ユーザー |
![]() |
提出日時 | 2019-01-13 02:36:35 |
言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 148 ms / 2,000 ms |
コード長 | 894 bytes |
コンパイル時間 | 653 ms |
コンパイル使用メモリ | 83,000 KB |
実行使用メモリ | 42,752 KB |
最終ジャッジ日時 | 2024-12-23 21:39:36 |
合計ジャッジ時間 | 2,509 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 21 |
コンパイルメッセージ
main.cpp: In function ‘int main()’: main.cpp:43:8: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result] 43 | scanf("%d%d", &r0, &r1); | ~~~~~^~~~~~~~~~~~~~~~~~
ソースコード
/* -*- coding: utf-8 -*- * * 781.cc: No.781 円周上の格子点の数え上げ - yukicoder */ #include<cstdio> #include<cstdlib> #include<cstring> #include<cmath> #include<iostream> #include<string> #include<vector> #include<map> #include<set> #include<stack> #include<list> #include<queue> #include<deque> #include<algorithm> #include<numeric> #include<utility> #include<complex> #include<functional> using namespace std; /* constant */ const int MAX_R = 10000000; /* typedef */ /* global variables */ int cnts[MAX_R + 1]; /* subroutines */ /* main */ int main() { int r0, r1; scanf("%d%d", &r0, &r1); for (int y = 0, yy = 0; yy <= r1; y++, yy = y * y) for (int x = 1, xx = 1; xx + yy <= r1; x++, xx = x * x) cnts[xx + yy]++; int maxc = 0; for (int r = r0; r <= r1; r++) if (maxc < cnts[r]) maxc = cnts[r]; printf("%d\n", maxc * 4); return 0; }