結果

問題 No.502 階乗を計算するだけ
コンテスト
ユーザー h173309
提出日時 2020-05-06 07:41:00
言語 Python3
(3.14.3 + numpy 2.4.4 + scipy 1.17.1)
コンパイル:
python3 -mpy_compile _filename_
実行:
python3 _filename_
結果
MLE  
実行時間 -
コード長 497 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 377 ms
コンパイル使用メモリ 20,828 KB
実行使用メモリ 750,884 KB
最終ジャッジ日時 2026-03-16 09:30:27
合計ジャッジ時間 27,297 ms
ジャッジサーバーID
(参考情報)
judge3_0 / judge2_0
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 33 TLE * 10 MLE * 9
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

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