Two Pointer

2024. 7. 23. 16:29·Algorithm/내용 정리

 

❒ Description


Trapping Rain water 문제를 풀면서 사용한 Two-Pointer 알고리즘에 대한 정리

 

 

 

 

❒ Two Pointer


1. Two Pointer 알고리즘이란?

주로 정렬된 배열에서 두 개의 Pointer를 사용하여 특정 조건을 만족할 때 까지 탐색하는 알고리즘이다.

해당 알고리즘의 동작원리는 다음과 같다.

  1. 초기화
    • 배열의 시작점 또는 특정 위치에 두개의 포인터를 배치. (일반적으로 시작과 끝에 배치)
  2. 조건 검색 및 이동
    • 각 포인터가 가리키는 요소를 검사하여 조건을 만족하는지 확인한다.
    • 조건을 만족하지 않으면 포인터를 이동시킨다.
  3. 종료 조건
    • 포인터가 배열의 끝에 도달하고나, 두 pointer가 교차할 때 반복을 종료한다.
    • 이때 원하는 결과를 얻었는지 확인한다.

 

2. 언제 사용하면 좋을까?

주로 정렬된 배열이나 리스트와 같은 선형 자료구조를 다루는 문제에서 효과적이다.

  • 부분 배열의 합이나 평균 계산을 요구하는 문제
  • 두 수의 합을 요구하는 문제
  • 두 정렬된 배열에서 공통 요소를 찾는 문제
  • 배열 내 특정 조건을 만족하는 구간 찾기 (Sliding Window Technique)
  • 회문 검사 (Palindrome Check)
  • K번째 작은 수 찾기
  • 두 개의 정렬된 배열을 하나의 정렬된 배열로 병합하는 문제
  • 모든 0을 배열의 끝으로 이동하는 문제

 

3. 시간 복잡도

정렬된 배열 및 리스트에서는 O(n)의 시간 복잡도를 갖는다.

하지만 정렬이 되지 않은 경우에는 평균적으로 O(nlogn)의 시간 복잡도를 갖는다.

 

 

 

❒ 해결 가능 문제


  • [LeetCode#42] Trapping rain water
  • [LeetCode#15] 3Sum

 

 

 

 

 


'Algorithm > 내용 정리' 카테고리의 다른 글

Dijkstra & Floyd-Warshall  (0) 2024.09.17
Floyd Warshall 알고리즘  (0) 2024.09.14
Dijkstra 알고리즘  (0) 2024.09.10
위상 정렬(Topological Sorting)  (0) 2024.08.30
Circular Deque의 두 가지 구현  (0) 2024.08.05
'Algorithm/내용 정리' 카테고리의 다른 글
  • Floyd Warshall 알고리즘
  • Dijkstra 알고리즘
  • 위상 정렬(Topological Sorting)
  • Circular Deque의 두 가지 구현
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
    Back-Tracking
    부분단조성
    Two-Pointer
    greedy
    sliding-window
    오블완
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.2
gilbert9172
Two Pointer
상단으로

티스토리툴바