結果
問題 | No.1050 Zero (Maximum) |
ユーザー | 6soukiti29 |
提出日時 | 2020-05-27 13:52:22 |
言語 | Nim (2.0.2) |
結果 |
CE
(最新)
AC
(最初)
|
実行時間 | - |
コード長 | 939 bytes |
コンパイル時間 | 944 ms |
コンパイル使用メモリ | 66,572 KB |
最終ジャッジ日時 | 2024-11-14 22:34:38 |
合計ジャッジ時間 | 1,379 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
コンパイルエラー時のメッセージ・ソースコードは、提出者また管理者しか表示できないようにしております。(リジャッジ後のコンパイルエラーは公開されます)
ただし、clay言語の場合は開発者のデバッグのため、公開されます。
ただし、clay言語の場合は開発者のデバッグのため、公開されます。
コンパイルメッセージ
/home/judge/data/code/Main.nim(7, 30) Error: type mismatch: got 'seq[int]' for 'map(split(readLine(stdin), {' ', '\t', '\v', '\r', '\n', '\f'}, -1), parseInt)' but expected 'tuple'
ソースコード
import sequtils,strutils var M, K : int mat : array[51,array[51, int64]] modnum : int64 = 1000_000_007 (M, K) = stdin.readline.split.map(parseInt) for n in 0..<M: var t : int for i in 0..<M: t = (n + i) mod M mat[t][n] += 1 t = (n * i) mod M mat[t][n] += 1 proc multi(A, B : array[0..50, array[0..50, int64]]): array[51, array[51,int64]]= var L = M for i in 0..<L: for j in 0..<L: for k in 0..<L: result[i][j] += A[i][k] * B[k][j] result[i][j] = result[i][j] mod modnum proc powmat(A : array[0..50, array[0..50, int64]], m : int) : array[51, array[51,int64]]= if m == 1: return A if m == 0: for i in 0..M: result[i][i] = 1 if m mod 2 == 0: return powmat(multi(A,A), m div 2) return multi(powmat(multi(A, A) , m div 2), A) mat = powmat(mat, K) echo mat[0][0]