結果
問題 | No.1501 酔歩 |
ユーザー |
|
提出日時 | 2023-07-30 15:35:08 |
言語 | PyPy3 (7.3.15) |
結果 |
RE
|
実行時間 | - |
コード長 | 811 bytes |
コンパイル時間 | 185 ms |
コンパイル使用メモリ | 81,852 KB |
実行使用メモリ | 92,444 KB |
最終ジャッジ日時 | 2024-10-09 10:47:53 |
合計ジャッジ時間 | 8,749 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 3 RE * 50 |
ソースコード
# import pypyjit # pypyjit.set_param('max_unroll_recursion=-1') from collections import * from itertools import * from functools import * from heapq import * import sys,math input = sys.stdin.readline N,K = map(int,input().split()) A = list(map(int,input().split())) val = [(-1,-1) for _ in range(N)] val[1] = (1,1) val[0] = (0,1) def f(x): if val[x]!=(-1,-1): return val[x] p1,q1 = f(x-1) p0,q0 = f(x-2) lx,ly = A[x]+A[x-2],A[x] rx,ry = A[x-2],A[x] ax,ay = lx*p1,ly*q1 bx,by = rx*p0,ry*q0 s = ax*by - bx*ay t = ay*by g = math.gcd(s,t) val[x] = (s//g,t//g) return val[x] pn,qn = f(N-1) if N==1: print(1) exit() if K==1: print(0) exit() pk,qk = f(K-1) s = pk*qn t = pn*qk g = math.gcd(s,t) s //=g t //=g print(str(s)+'/'+str(t))