結果
| 問題 |
No.273 回文分解
|
| コンテスト | |
| ユーザー |
convexineq
|
| 提出日時 | 2020-12-19 23:42:41 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 54 ms / 2,000 ms |
| コード長 | 379 bytes |
| コンパイル時間 | 708 ms |
| コンパイル使用メモリ | 81,840 KB |
| 実行使用メモリ | 67,260 KB |
| 最終ジャッジ日時 | 2024-09-21 10:46:06 |
| 合計ジャッジ時間 | 3,078 ms |
|
ジャッジサーバーID (参考情報) |
judge2 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 32 |
ソースコード
s = input()
n = len(s)
dp = [[-1]*(n+1) for _ in range(n+1)]
for l in range(n,-1,-1):
for r in range(l+1,n+1):
if (l != 0 or r != n) and s[l:r] == s[l:r][::-1]:
dp[l][r] = r-l
else:
for x in range(l+1,r):
if dp[l][x] >= 0 and dp[x][r] >= 0:
dp[l][r] = max(dp[l][r],dp[l][x],dp[x][r])
print(dp[l][r])
convexineq