- 가장 긴 팰린드롬
문제 설명
입출력 예sanswer
입출력 예 설명
앞뒤를 뒤집어도 똑같은 문자열을 팰린드롬(palindrome)이라고 합니다.
문자열 s가 주어질 때, s의 부분문자열(Substring)중 가장 긴 팰린드롬의 길이를 return 하는 solution 함수를 완성해 주세요.
예를들면, 문자열 s가 "abcdcba"이면 7을 return하고 "abacde"이면 3을 return합니다.
제한사항- 문자열 s의 길이 : 2,500 이하의 자연수
- 문자열 s는 알파벳 소문자로만 구성
입출력 예sanswer
"abcdcba" | 7 |
"abacde" | 3 |
입출력 예 #1
4번째자리 'd'를 기준으로 문자열 s 전체가 팰린드롬이 되므로 7을 return합니다.
입출력 예 #2
2번째자리 'b'를 기준으로 "aba"가 팰린드롬이 되므로 3을 return합니다.
def solution(s):
answer = 0
L = len(s)
for i in range(L):
for j in range(L, -1, -1):
if s[i] != s[j-1]:
continue
if s[i:j] == s[i:j][::-1]:
answer = max(answer, len(s[i:j]))
break
if answer >= L-i:
break
return answer
'알고리즘 공부💥 > 프로그래머스' 카테고리의 다른 글
[프로그래머스] 멀리뛰기 / Python (0) | 2022.05.30 |
---|---|
[프로그래머스] 입국 심사 (0) | 2022.05.16 |
[프로그래머스] k진수에서 소수 개수 구하기 (0) | 2022.05.09 |
[프로그래머스] N개의 최소공배수 (0) | 2022.05.09 |
[프로그래머스] 방금그곡 / javascript (0) | 2022.03.07 |