[리트코드] 680. Valid Palindrome II - python 본문

코테 문제 풀이

[리트코드] 680. Valid Palindrome II - python

미니모아 2022. 4. 13. 16:50
반응형

680. Valid Palindrome II

문제

Given a string s, return true if the s can be palindrome after deleting at most one character from it.

최대 하나의 문자를 제거해서 팰린드롭이 될 수 있는지 확인하는 문제

제한사항

  • 1 <= s.length <= 105
  • s consists of lowercase English letters.

풀이

start와 end를 순회하다가 s[start]와 s[end]가 같지 않은 부분이 생기면 두 가지로 분기한다.

  • s[start] 를 제거하는 방법
  • s[end]를 제거하는 방법

최대 한번 제거하라고 했으므로, 한 번 제거 후에도 팰린드롭이 되지 않는다면 종료한다.

abca

a --- a

b----c

b제거 하는 경우

c제거 하는 경우

class Solution:
    def makePalindrome(self, s:str, start:int, end: int, changed:int):
        if changed > 1:
            return False
        
        while start < end:
            if s[start] != s[end]:
                return self.makePalindrome(s, start + 1, end, changed + 1) or self.makePalindrome(s, start, end -1, changed + 1)
            start += 1
            end -= 1
        return True
                
    def validPalindrome(self, s: str) -> bool:
        return self.makePalindrome(s, 0, len(s) - 1, 0)

최대 한 번이기 때문에 백트래킹을 사용하지 않고 더 간단하게 정리할 수도 있다.

일치하지 않은 케이스와 start를 제거한 부분과 end를 제거한 케이스로 슬라이싱 한 후 둘 중에 하나라도 팰린드롭인지 확인하면된다.

class Solution:
    def validPalindrome(self, s: str) -> bool:
        start, end = 0, len(s) - 1
        
        while start <= end:
            if s[start] != s[end]:
                case1 = s[start: end] # end 제거
                case2 = s[start + 1: end + 1]# start 제거
                
                return case1 == case1[::-1] or case2 == case2[::-1]
            start += 1
            end -= 1
        
        return True

 

반응형
Comments