結果
| 問題 | No.428 小数から逃げる夢 | 
| コンテスト | |
| ユーザー |  | 
| 提出日時 | 2022-12-24 00:03:08 | 
| 言語 | PyPy3 (7.3.15) | 
| 結果 | 
                                AC
                                 
                             | 
| 実行時間 | 48 ms / 1,000 ms | 
| コード長 | 656 bytes | 
| コンパイル時間 | 572 ms | 
| コンパイル使用メモリ | 82,304 KB | 
| 実行使用メモリ | 54,504 KB | 
| 最終ジャッジ日時 | 2024-11-18 04:50:15 | 
| 合計ジャッジ時間 | 7,156 ms | 
| ジャッジサーバーID (参考情報) | judge3 / judge2 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| other | AC * 100 | 
ソースコード
d = [0]
for i in range(1, 100):
    if i < 10:
        d.append(i)
    else:
        q, r = divmod(i, 10)
        d.append(q)
        d.append(r)
d.append(1)
n = int(input())
m = len(d)
for i in range(m - 1, -1, -1):
    d[i] *= n
for i in range(m - 1, 0, -1):
    if 10 <= d[i] < 100:
        q, r = divmod(d[i], 10)
        d[i] = r
        d[i - 1] += q
    else:
        q, r = divmod(d[i], 100)
        qq, r = divmod(r, 10)
        if i == 1:
            d[i] = r
            d[i - 1] += q * 10 + qq
        else:
            d[i] = r
            d[i - 1] += qq
            d[i - 2] += q
ans = str(d[0]) + '.' + ''.join(map(str, d[1:]))
print(ans)
            
            
            
        