Algorithm Guidecomplexity: O(n + m)
KMP 문자열 탐색 (Knuth-Morris-Pratt)
실패 함수(LPS)를 미리 계산해, 불일치가 나도 패턴을 처음부터 다시 비교하지 않고 건너뛰는 문자열 탐색입니다. 텍스트 포인터를 되돌리지 않아 O(n+m)에 매칭합니다.
01 알고리즘 작동 원리 탐색
Interactive Step-by-StepTAP OR HOVER
KMP · pattern "ABABC"
Logic Node1 / 7
Live Python
02 쉽게 이해하기
For Everyone🔑비유
헛걸음을 기억해두는 똑똑한 찾기 — 이미 맞춰본 부분은 다시 보지 않습니다.
💡쉽게 말하면
패턴의 실패 함수(LPS)를 미리 계산해, 불일치가 나도 텍스트를 되돌리지 않고 패턴만 건너뜁니다.
비교를 낭비하지 않아 O(n+m)에 매칭해요.
📍어디에 쓰나
- –텍스트 검색
- –로그·DNA 서열 매칭
- –grep류 도구
03 파이썬 구현 코드
KMP 문자열 탐색 (Knuth-Morris-Pratt)의 핵심 로직을 담은 표준 구현 예시입니다. 가급적 간결하고 읽기 쉬운 코드로 작성되었습니다.
core_implementation.py
Guide Progress0%
