結果

問題 No.1050 Zero (Maximum)
ユーザー 6soukiti296soukiti29
提出日時 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言語の場合は開発者のデバッグのため、公開されます。

コンパイルメッセージ
/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'

ソースコード

diff #

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]







0