MST 에 관하여
·
algorithm
최소 신장 트리(MST, Minimum Spanning Tree)는 그래프 내의 모든 정점을 연결하는 최소 비용의 간선 집합으로 이루어진 트리를 의미합니다. 즉, 그래프의 모든 노드를 최소 비용으로 연결하는 것입니다.1. MST의 특징모든 정점이 연결되어 있어야 합니다.사이클을 포함해서는 안 됩니다.최소한의 비용으로 구성됩니다.2. MST 알고리즘 종류최소 신장 트리를 구하는 대표적인 알고리즘은 다음과 같습니다.2-1. 크루스칼(Kruskal) 알고리즘시간 복잡도: O(ElogE)간선의 비용을 기준으로 오름차순으로 정렬한 후, 사이클을 형성하지 않도록 최소 비용 간선을 순차적으로 선택합니다.2-2. 프림(Prim) 알고리즘시간 복잡도: O(ElogV)시작 정점에서부터 시작하여 연결된 정점들 중 최소 비용..
LCA 에 관하여
·
algorithm
최소 공통 조상(LCA, Lowest Common Ancestor) 이란 트리에서 두 노드의 가장 가까운 공통 조상을 의미합니다. 이는 트리 구조에서 두 노드 간의 관계를 파악하거나 최단 거리 등을 찾을 때 유용하게 사용됩니다.1. 최소 공통 조상의 필요성트리에서 두 노드 간의 관계 파악효율적인 최단 경로 탐색2. LCA 알고리즘의 종류LCA를 구현하는 대표적인 방법은 다음과 같습니다.1. 단순 탐색시간 복잡도: O(N)가장 간단한 방법으로, 루트에서부터 탐색하여 두 노드의 공통 조상을 찾습니다.2. 이진 트리에서의 재귀적 탐색시간 복잡도: O(N)트리를 한 번 순회하면서 두 노드의 공통 조상을 찾습니다.3. Sparse Table (희소 테이블)시간 복잡도: 전처리 O(NlogN), 쿼리 O(logN)..
세그먼트 트리에 관하여
·
algorithm
세그먼트 트리는 구간 쿼리를 효율적으로 처리하기 위한 트리 형태의 자료구조로, 배열 내 특정 범위의 합, 최소값, 최대값 등의 연산을 빠르게 수행할 수 있습니다. 1. 세그먼트 트리의 구조세그먼트 트리는 배열을 구간 단위로 나누어 트리 형태로 표현합니다. 트리의 각 노드는 배열의 특정 구간을 나타내며, 노드의 값은 해당 구간의 연산(합, 최소값 등) 결과를 저장합니다.장점: 구간 연산을 효율적으로 수행 가능단점: 메모리 사용량이 높음2. 세그먼트 트리의 동작 원리세그먼트 트리는 크게 다음 두 가지 연산을 지원합니다.구간 질의(Query)특정 구간에 대한 합, 최소값, 최대값 등의 값을 빠르게 얻을 수 있습니다.값 갱신(Update)특정 위치의 값을 변경하면 연관된 모든 노드의 값을 갱신합니다.3. 시간 ..
트라이(Trie) 알고리즘에 관하여
·
algorithm
트라이는 문자열을 효율적으로 저장하고 탐색하기 위한 트리 자료구조로, 특히 접두사를 공유하는 문자열 집합에서 강력한 성능을 발휘합니다. 1. 트라이의 개념과 구조트라이(Trie)는 트리 형태의 자료구조로, 문자열의 각 문자를 노드로 저장하여 문자열을 효율적으로 탐색할 수 있도록 구성됩니다. 트라이의 각 노드는 문자의 존재 여부를 나타내며 자식 노드를 통해 문자열이 이어집니다.장점: 빠른 문자열 탐색, 자동완성 기능 지원단점: 공간 복잡도가 상대적으로 높음2. 트라이 알고리즘의 동작 원리트라이 알고리즘은 크게 세 가지 연산으로 이루어집니다.문자열 삽입 (insert)문자열을 노드 단위로 삽입하며, 마지막 문자 노드에 문자열의 끝을 표시합니다.문자열 검색 (search)트리를 순회하며 문자열이 존재하는지 확..
이분 탐색 + 휴리스틱 기법에 관하여
·
algorithm
이분 탐색(Binary Search) 은 정렬된 데이터에서 빠르게 원하는 값을 찾는 알고리즘입니다. 하지만 이분 탐색만으로는 실전 문제 해결에서 최적의 성능을 내기 어려운 경우가 많습니다. 이럴 때, 추가적인 휴리스틱(Heuristic) 기법을 적용하면 탐색 속도를 높이고 효율적으로 문제를 해결할 수 있습니다. 1. 이분 탐색(Binary Search) 개요이분 탐색은 데이터가 정렬되어 있을 때, 탐색 범위를 절반씩 줄여가며 원하는 값을 찾는 방법입니다. 일반적으로 시간 복잡도는 O(logN) 이며, 빠른 탐색이 가능합니다.2. 휴리스틱 기법이란?휴리스틱(Heuristic)은 완전한 최적해를 찾는 것이 아니라, 근사적인 최적해를 빠르게 찾는 방법입니다. 이는 문제의 특성을 이용하여 탐색 범위를 줄이거나,..
랜덤 액세스 링크드 리스트에 관하여
·
algorithm
랜덤 액세스 링크드 리스트(Random Access Linked List)는 기존의 연결 리스트(Linked List)의 단점인 느린 인덱스 접근(Random Access 불가능) 을 보완하기 위해 설계된 자료구조입니다.일반적인 연결 리스트는 특정 인덱스에 접근하기 위해 O(n) 시간이 소요되는 반면, 랜덤 액세스 링크드 리스트는 O(log n) 혹은 O(1) 수준의 빠른 접근이 가능하도록 최적화된 구조를 가집니다.1. 기존 연결 리스트의 문제점일반적인 단일/이중 연결 리스트는 연속적인 메모리 공간이 아니라, 노드들이 포인터를 통해 연결된 형태이기 때문에 특정 위치의 데이터를 찾기 위해 항상 순차 탐색(Sequential Access) 해야 합니다.배열(Array)의 경우 O(1) 시간 복잡도로 즉시 원..
슬라이딩 윈도우 알고리즘에 관하여
·
algorithm
슬라이딩 윈도우(Sliding Window)는 배열이나 문자열과 같은 데이터 구조에서 특정 조건에 맞는 부분 구간을 효율적으로 탐색하거나 계산하기 위한 알고리즘 기법입니다. 이 글에서는 슬라이딩 윈도우 알고리즘의 개념, 작동 원리, 주요 사례 및 구현 방법에 대해 알아보겠습니다.1. 슬라이딩 윈도우 알고리즘이란?슬라이딩 윈도우는 고정된 크기의 윈도우(구간)를 데이터 구조 위에서 이동시키며 문제를 해결하는 방식입니다. 반복적으로 윈도우를 이동하면서 이전 계산 결과를 활용하여 효율적인 처리를 제공합니다.사용 목적불필요한 계산을 줄여 성능 최적화특정 구간 내의 값을 계산하거나 조건을 만족하는 부분을 탐색2. 작동 원리슬라이딩 윈도우는 기본적으로 두 개의 포인터(보통 시작 포인터와 끝 포인터)를 사용하여 데이터..