結果
問題 |
No.2443 特殊線形群の標準表現
|
ユーザー |
![]() |
提出日時 | 2023-08-28 03:09:03 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 730 ms / 3,000 ms |
コード長 | 887 bytes |
コンパイル時間 | 665 ms |
コンパイル使用メモリ | 82,432 KB |
実行使用メモリ | 143,084 KB |
最終ジャッジ日時 | 2024-12-28 17:15:00 |
合計ジャッジ時間 | 7,865 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 21 |
ソースコード
import sys input = sys.stdin.readline N,mod,Q=map(int,input().split()) def prod(A,B,k,l,m):# A:k*l,B:l*m C=[[None for i in range(m)] for j in range(k)] for i in range(k): for j in range(m): ANS=0 for pl in range(l): ANS=(ANS+A[i][pl]*B[pl][j])%mod C[i][j]=ANS return C A=[] for i in range(N): x,y=map(int,input().split()) z,w=map(int,input().split()) A.append([[x,y],[z,w]]) S=[[[1,0],[0,1]]] for i in range(N): a=A[i] S.append(prod(a,S[-1],2,2,2)) for tests in range(Q): l,r,x,y=map(int,input().split()) if l==r: print(x%mod,y%mod) continue k=S[l] k0,k1=k[0] k2,k3=k[1] L= prod(S[r],[[k3,-k1],[-k2,k0]],2,2,2) #print(S[r],k,[[k3,-k1],[-k2,k0]],L) k0,k1=L[0] k2,k3=L[1] print((x*k0+y*k1)%mod,(x*k2+y*k3)%mod)