結果

問題 No.294 SuperFizzBuzz
ユーザー mkawa2mkawa2
提出日時 2020-02-06 11:27:11
言語 PyPy3
(7.3.13)
結果
WA  
実行時間 -
コード長 818 bytes
コンパイル時間 152 ms
コンパイル使用メモリ 81,708 KB
実行使用メモリ 79,628 KB
最終ジャッジ日時 2023-10-25 22:01:15
合計ジャッジ時間 6,672 ms
ジャッジサーバーID
(参考情報)
judge12 / judge13
このコードへのチャレンジ(β)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 WA -
testcase_01 WA -
testcase_02 TLE -
testcase_03 -- -
testcase_04 -- -
testcase_05 -- -
testcase_06 -- -
testcase_07 -- -
testcase_08 -- -
testcase_09 -- -
testcase_10 -- -
testcase_11 -- -
testcase_12 -- -
testcase_13 -- -
testcase_14 -- -
権限があれば一括ダウンロードができます

ソースコード

diff #

import sys

sys.setrecursionlimit(10 ** 6)

def II(): return int(sys.stdin.readline())



def main():
    fac=[1]
    for i in range(1,30):fac.append(fac[-1]*i)
    def nCr(n,r):
        if n<r:return 0
        return fac[n]//fac[r]//fac[n-r]

    def num(k):
        res=0
        for c5 in range(2,k,3):
            res+=nCr(k-1,c5)
        return res

    n=II()
    inf=10**9
    cnt=0
    for k in range(inf):
        tmp=num(k)
        if cnt+tmp>=n:break
        cnt+=tmp
    k-=1
    print(k)
    for bit in range(1<<k):
        if bin(bit).count("1")%3==2:
            cnt+=1
            #print(bin(bit)[2:].zfill(k))
        if cnt==n:
            ans=""
            for i in range(k):
                ans+="5" if bit>>k-1-i&1 else "3"
            ans+="5"
            print(ans)
            exit()


main()
0