[LeetCode#131] Palindrome Partitioning

2024. 11. 24. 19:36·Algorithm/문제풀이

 

❐ Description


이번 문제도 [LeetCode#93] Restore IP Addresses와 마찬가지로  문자열을 동적으로

분할하는 로직이 추가적으로 필요하다.

 

 

 

 

 

❐ 풀이 전략


☑️ 주어진 문자열의 분할 시작점을 cursor 변수에 저장한다.

☑️ cursor를 시작으로 하는 for문 input의 길이만큼 순회한다. (int i = cursor;)

☑️ 부분 문자열의 Palindrome 여부를 확인한다.

☑️ 시작 : cursor, 종료 : i + 1

 

 

 

 

 

❐ Solution


public class Solution {

    private final List<List<String>> subsets = new ArrayList<>();

    public List<List<String>> partition(String s) {
        backTracking(s, 0, new ArrayList<>());
        return subsets;
    }

    private void backTracking(
            String input,
            int cursor,
            List<String> subset
    ) {
        if (input.length() == cursor) {
            subsets.add(new ArrayList<>(subset));
            return;
        }

        for (int i = cursor; i < input.length(); i++) {
            if (isPalindrome(input, cursor, i)) {
                String substring = input.substring(cursor, i + 1);
                subset.add(substring);
                backTracking(input, i + 1, subset);
                subset.removeLast();
            }
        }
    }

    private boolean isPalindrome(String input, int start, int end) {
        while (start <= end) {
            char startChar = input.charAt(start);
            char endChar = input.charAt(end);
            start++;
            end--;
            if (startChar != endChar) {
                return false;
            }
        }
        return true;
    }
}

 

 

'Algorithm > 문제풀이' 카테고리의 다른 글

[LeetCode#2517] Maximum Tastiness of Candy Basket  (0) 2024.12.20
[LeetCode#130] Surrounded Regions  (0) 2024.12.14
[LeetCode#93] Restore IP Addresses  (0) 2024.11.24
[LeetCode#47] Permutation Ⅱ  (0) 2024.11.19
[LeetCode#424] Longest Repeating Character Replacement  (0) 2024.11.15
'Algorithm/문제풀이' 카테고리의 다른 글
  • [LeetCode#2517] Maximum Tastiness of Candy Basket
  • [LeetCode#130] Surrounded Regions
  • [LeetCode#93] Restore IP Addresses
  • [LeetCode#47] Permutation Ⅱ
gilbert9172
gilbert9172
gilbert9172 님의 블로그 입니다.
  • gilbert9172
    バックエンド
    gilbert9172
  • 전체
    오늘
    어제
    • All Categories (175)
      • 우테코 7기 (21)
        • 1주차 (8)
        • 2주차 (5)
        • 3주차 (6)
      • Langauge (4)
        • Java (3)
        • Kotlin (1)
      • Back-End (13)
        • SpringBoot (1)
        • Trouble Shooting (0)
        • Setup & Configuration (1)
        • SQL (3)
        • Redis (8)
      • Architecture (6)
        • Multi Module (1)
        • DDD (5)
      • CS (30)
        • Data Structure (6)
        • Operating System (0)
        • Network (12)
        • Database (10)
        • Design Pattern (2)
      • Algorithm (78)
        • 내용 정리 (18)
        • 문제풀이 (60)
      • DevOps (6)
        • AWS (5)
        • Git (1)
      • Front-End (1)
        • Trouble Shooting (1)
      • Project (6)
        • 페이스콕 (6)
      • Book (9)
        • 이벤트 기반 마이크로서비스 구축 (7)
        • 친절한 SQL 튜닝 (2)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    binarysearch
    sliding-window
    부분단조성
    오블완
    Back-Tracking
    greedy
    Two-Pointer
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.2
gilbert9172
[LeetCode#131] Palindrome Partitioning
상단으로

티스토리툴바