結果

問題 No.502 階乗を計算するだけ
ユーザー h173309
提出日時 2020-05-06 07:41:00
言語 Python3
(3.13.1 + numpy 2.2.1 + scipy 1.14.1)
結果
TLE  
実行時間 -
コード長 497 bytes
コンパイル時間 114 ms
コンパイル使用メモリ 12,416 KB
実行使用メモリ 377,728 KB
最終ジャッジ日時 2024-06-28 01:20:39
合計ジャッジ時間 5,199 ms
ジャッジサーバーID
(参考情報)
judge5 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 32 TLE * 1 -- * 19
権限があれば一括ダウンロードができます

ソースコード

diff #

class Factorial():
    def __init__(self, mod=10**9 + 7):
        self.mod = mod
        self._factorial = [1]
        self._size = 1
    
    def __call__(self, n):
        '''n! % mod'''
        if n >= self.mod:
            return 0
        if self._size < n+1:
            for i in range(self._size, n+1):
                self._factorial.append(self._factorial[-1]*i % self.mod)
        self._size = n+1
        return self._factorial[n]
factorial = Factorial()

print(factorial(int(input())))
0