結果
| 問題 |
No.1740 Alone 'a'
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2024-11-24 23:45:11 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 196 ms / 2,000 ms |
| コード長 | 1,149 bytes |
| コンパイル時間 | 230 ms |
| コンパイル使用メモリ | 82,324 KB |
| 実行使用メモリ | 67,320 KB |
| 最終ジャッジ日時 | 2024-11-24 23:45:15 |
| 合計ジャッジ時間 | 3,026 ms |
|
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 38 |
ソースコード
## https://yukicoder.me/problems/no/1740
MOD = 998244353
def main():
N = int(input())
S = input()
answer = 0
has_one_a = False
for i in range(N - 1):
s = S[i]
if s >= "b":
if not has_one_a:
answer += pow(25, N - 1 - i, MOD)
answer %= MOD
if s >= "c":
v = ord(s) - 1 - ord("a")
if not has_one_a:
ans = ((N - 1 - i) * pow(25, N - 2 - i, MOD)) % MOD
answer += (v * ans) % MOD
answer %= MOD
else:
answer += (v * pow(25, N - 1 - i, MOD)) % MOD
answer %= MOD
if s == "a":
if not has_one_a:
has_one_a = True
else:
print(answer)
return
# 最後の一つについて
s = ord(S[-1]) - ord("a")
for t in range(s):
if t == 0 and not has_one_a:
answer += 1
answer %= MOD
if t > 0 and has_one_a:
answer += 1
answer %= MOD
print(answer)
if __name__ == "__main__":
main()