[LeetCode#92] Reverse Linked List II

2024. 7. 28. 17:38·Algorithm/문제풀이

❒ Description


제목Reverse Linked List II
링크https://leetcode.com/problems/reverse-linked-list-ii/
자료구조선형 (연결 리스트)
시간복잡도O(n)


이번 문제에서는 기억하고 있으면 나중에 사용하기 좋은 공식? 같은 것들을 알았다.

  • 가상의 노드 Root 생성하기
  • 특정 범위의 노드의 순서만 변경하기.

 
 
 

❒ Solution


public ListNode reverseBetween(ListNode head, int left, int right) {
    if (head == null) {
        return null;
    }
    // 가상의 노드 생성하기
    ListNode root = new ListNode(0);
    root.next = head;

    // 노드 변경 시작점으로 이동하기
    ListNode start = root;
    for (int i = 0; i < left - 1; i++) {
        start = start.next;
    }
    // 가장 가까운 변경 마지막 노드 설정하기
    ListNode end = start.next;

    // 해당 범위의 노드 순서 변경하기
    for (int i = 0; i < right - left; i++) {
        ListNode tmp = start.next;
        start.next = end.next;
        end.next = end.next.next;
        start.next.next = tmp;
    }
    return root.next;
}

 
이번 문제에서는 아래의 아이디어가 핵심으로 느껴진다.

  • `left-1`로 변경해야 할 노드의 시작 점을 찾는다.
  • `right - left` 로 변경해야 할 노드들만 타켓팅한다.
  • 임시 변수를 활용하기.

그림을 통해 직관화
위 풀이를 이미지화

temp만 한 칸씩 앞으로 이동하고, start와 end는 각각 1과 2로 정되어 있다.

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

[LeetCode#622] Design Circular Queue  (0) 2024.08.04
[LeetCode#739] Daily Temperatures  (0) 2024.07.31
[LeetCode#24] Swap Nodes In Pairs  (0) 2024.07.28
[LeetCode#206] Reverse Linked List  (0) 2024.07.28
[LeetCode#21] Merge Two Sorted Lists  (0) 2024.07.24
'Algorithm/문제풀이' 카테고리의 다른 글
  • [LeetCode#622] Design Circular Queue
  • [LeetCode#739] Daily Temperatures
  • [LeetCode#24] Swap Nodes In Pairs
  • [LeetCode#206] Reverse Linked List
gilbert9172
gilbert9172
gilbert9172 님의 블로그 입니다.
  • gilbert9172
    バックエンド
    gilbert9172
  • 전체
    오늘
    어제
    • All Categories (207)
      • 우테코 7기 (21)
        • 1주차 (8)
        • 2주차 (5)
        • 3주차 (6)
      • Langauge (6)
        • Java (3)
        • Kotlin (3)
      • 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 (39)
        • 친절한 SQL 튜닝 (9)
        • 데이터 중심 애플리케이션 설계 (14)
        • 이벤트 기반 마이크로서비스 구축 (6)
        • Spring Batch docs (10)
        • Quartz docs (0)
  • 블로그 메뉴

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

  • 공지사항

  • 인기 글

  • 태그

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

  • 최근 글

  • hELLO· Designed By정상우.v4.10.2
gilbert9172
[LeetCode#92] Reverse Linked List II
상단으로

티스토리툴바