結果
| 問題 |
No.1171 Runs in Subsequences
|
| コンテスト | |
| ユーザー |
👑 SPD_9X2
|
| 提出日時 | 2020-08-14 22:00:45 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 223 ms / 2,000 ms |
| コード長 | 676 bytes |
| コンパイル時間 | 481 ms |
| コンパイル使用メモリ | 82,176 KB |
| 実行使用メモリ | 76,800 KB |
| 最終ジャッジ日時 | 2024-10-10 15:15:04 |
| 合計ジャッジ時間 | 3,395 ms |
|
ジャッジサーバーID (参考情報) |
judge1 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 4 |
| other | AC * 18 |
ソースコード
"""
https://yukicoder.me/problems/no/1171
runが増えるのは、新たな文字を追加する場合
入れる・入れないを選べるので
dp[i][最後の文字] = 現在門戸を開いている数
同じ文字を重ねて置いた場合、門戸は増えるが連は増えない
"""
from sys import stdin
S = stdin.readline()
S = S[:-1]
alp = "abcdefghijklmnopqrstuvwxyz"
ad = {}
for i in range(26):
ad[alp[i]] = i
dp = [0] * 27
dp[-1] = 1
mod = 10**9+7
ans = 0
for loop in range(len(S)):
i = S[loop]
nsum = sum(dp) - dp[ad[i]]
ans += nsum * pow(2,len(S)-loop-1,mod)
ans %= mod
dp[ad[i]] += sum(dp)
dp[ad[i]] %= mod
print (ans)
SPD_9X2