結果
| 問題 |
No.1050 Zero (Maximum)
|
| コンテスト | |
| ユーザー |
6soukiti29
|
| 提出日時 | 2020-05-27 13:52:22 |
| 言語 | Nim (2.2.0) |
| 結果 |
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]
6soukiti29