[LeetCode#206] Reverse Linked List

2024. 7. 28. 00:23·Algorithm/문제풀이

❒ Description


제목 Reverse Linked List
링크 https://leetcode.com/problems/reverse-linked-list/
자료구조 선형 (연결리스트)

 

이번 문제는 연결리스트를 뒤집는 방법에 대해 알 수 있는 문제다.

기억해두면 쓸모가 있을 듯.

 

 

 

❒ Solve


1.  재귀 구조

public ListNode reverse(ListNode node, ListNode prev) {
    if (node == null) {
    	return prev;
    }
    ListNode next = node.next;
    node.next = prev;
    return reverse(next, node);
}

 

`1 → 2 → 3`를 reverse 하는 케이스

1st  2nd 3rd 4th
node = node(1)
prev = null
node = node(2)
prev = node(1)
node = node(3)
prev = node(2)
node = null
prev = node(3)
next = node(2) next = node(3) next = null  
node.next = null node.next = node(1) node.next = node(2)  
reverse(node(2), node(1)) ↗ reverse(node(3), node(2)) ↗ reverse(null, node(3)) ↗  
       
return node(3) ← return node(3) ← return node(3) ← return node(3)

 

 

 

2.  반복 구조로 뒤집기

public ListNode reverse(ListNode node) {
    ListNode prev = null;
    ListNode current = node;
    
    while(node != null) {
    	ListNode next = node.next;
        currnet.next = prev; 
        prev = node;
        current = next;
    }
    return prev;
}

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

[LeetCode#92] Reverse Linked List II  (0) 2024.07.28
[LeetCode#24] Swap Nodes In Pairs  (0) 2024.07.28
[LeetCode#21] Merge Two Sorted Lists  (0) 2024.07.24
[LeetCode#234] Palindrome Linked List  (0) 2024.07.24
[LeetCode#121] Best Time to Buy and Sell Stock  (0) 2024.07.24
'Algorithm/문제풀이' 카테고리의 다른 글
  • [LeetCode#92] Reverse Linked List II
  • [LeetCode#24] Swap Nodes In Pairs
  • [LeetCode#21] Merge Two Sorted Lists
  • [LeetCode#234] Palindrome 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)
  • 블로그 메뉴

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

  • 공지사항

  • 인기 글

  • 태그

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

  • 최근 글

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

티스토리툴바