ps:problems:boj:14444
목차
가장 긴 팰린드롬 부분 문자열
ps | |
---|---|
링크 | acmicpc.net/… |
출처 | BOJ |
문제 번호 | 14444 |
문제명 | 가장 긴 팰린드롬 부분 문자열 |
레벨 | 플래티넘 5 |
분류 |
Manacher |
시간복잡도 | O(n) |
인풋사이즈 | n<=100,000 |
사용한 언어 | Python |
제출기록 | 38420KB / 260ms |
최고기록 | 260ms |
해결날짜 | 2021/07/04 |
풀이
- 가장 긴 팰린드롬 부분 문자열 와 완벽히 동일한 문제.
- 말 그대로 가장 긴 팰린드롬 부분문자열 (Longest Palindromic Substring)을 구하는 문제. 링크에 설명된대로 Manacher's algorithm을 사용해서 O(n)에 풀수 있다.
코드
"""Solution code for "BOJ 14444. 가장 긴 팰린드롬 부분 문자열".
- Problem link: https://www.acmicpc.net/problem/14444
- Solution link: http://www.teferi.net/ps/problems/boj/14444
Tags: [Manacher]
"""
from teflib import string
def main():
S = input()
print(max(string.palindrome_radiuses('#' + '#'.join(S) + '#')))
if __name__ == '__main__':
main()
- Dependency: teflib.string.palindrome_radiuses
ps/problems/boj/14444.txt · 마지막으로 수정됨: 2021/07/04 15:32 저자 teferi
토론