結果
問題 |
No.781 円周上の格子点の数え上げ
|
ユーザー |
|
提出日時 | 2019-01-17 09:15:25 |
言語 | Nim (2.2.0) |
結果 |
RE
(最新)
AC
(最初)
|
実行時間 | - |
コード長 | 745 bytes |
コンパイル時間 | 3,424 ms |
コンパイル使用メモリ | 66,980 KB |
実行使用メモリ | 22,656 KB |
最終ジャッジ日時 | 2024-07-01 06:55:04 |
合計ジャッジ時間 | 4,921 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 17 RE * 4 |
コンパイルメッセージ
/home/judge/data/code/Main.nim(1, 41) Warning: imported and not used: 'sugar' [UnusedImport] /home/judge/data/code/Main.nim(1, 54) Warning: imported and not used: 'strformat' [UnusedImport] /home/judge/data/code/Main.nim(1, 26) Warning: imported and not used: 'algorithm' [UnusedImport]
ソースコード
import sequtils,strutils,algorithm,math,sugar,macros,strformat template get*():string = stdin.readLine().strip() macro unpack*(arr: auto,cnt: static[int]): auto = let t = genSym(); result = quote do:(let `t` = `arr`;()) for i in 0..<cnt: result[1].add(quote do:`t`[`i`]) template `max=`*(x,y) = x = max(x,y) proc sqrt(x:int):int = x.float.sqrt.int var results : array[1000_0010,int16] let (x,y) = get().split().map(parseInt).unpack(2) const INF = 1000_0000 let SQRTINF = y.sqrt + 1 for a in 0..SQRTINF: results[a * a] += 1 for a in 0..SQRTINF div 2: results[2 * a * a] += 1 for a in 1..SQRTINF: for b in (a+1)..sqrt(INF - a * a): var c = a * a + b * b results[c] += 2 var ans = 0 for r in x..y: ans .max= results[r] echo ans * 4