結果

問題 No.108 トリプルカードコンプ
コンテスト
ユーザー ygd.
提出日時 2021-01-28 00:54:58
言語 Python3
(3.14.3 + numpy 2.4.2 + scipy 1.17.0)
コンパイル:
python3 -mpy_compile _filename_
実行:
python3 _filename_
結果
AC  
実行時間 470 ms / 5,000 ms
コード長 776 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 420 ms
コンパイル使用メモリ 20,828 KB
実行使用メモリ 60,424 KB
最終ジャッジ日時 2026-03-11 06:39:19
合計ジャッジ時間 4,872 ms
ジャッジサーバーID
(参考情報)
judge3_1 / judge1_0
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 20
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

import copy
from functools import lru_cache
import sys
sys.setrecursionlimit(1000000)

N = int(input())
A = list(map(int,input().split()))

B = [min(A[i],3) for i in range(N)]
B = tuple(B)
#print(B)

#0,1,2,3以上個の数
C = [0,0,0,0]
for x in A:
    if x >=3 :
        C[3] += 1
    else:
        C[x] += 1
C = tuple(C)
#print(C)

@lru_cache(maxsize=None)
def solve(X):
    ret = N
    loop = N - X[3]
    #print(X)
    for i in range(3):
        if X[i] == 0: continue
        if i <= 2:
            Z = list(X)
            Z[i] -= 1
            Z[i+1] += 1
            Z = tuple(Z)
            ret += solve(Z)*X[i]
    #print("A",X,loop,ret)
    if loop == 0:
        ret = 0
    else:
        ret /= loop
    #print(X,loop,ret)
    return ret

ans = solve(C)
print(ans)
0