
백트래킹(Backtracking)은 해결책에 대한 후보를 구축해 나아가다 가능성이 없다고 판단되는 즉시 후보를 포기(백트랙)해 정답을 찾아가는 범용적인 알고리즘으로 제약 충족 문제(CSP/Constraint Satisfaction Problems)에 특히 유용하다.
가능한 한 모든 방법을 탐색하면서 해결책을 찾는데, 목표까지 가능성이 유망하지 않은 경로를 차단하고 가능성 있는 루트를 검색하는 방법이다.
백트래킹은 제약 충조 문제(CSP)를 풀이하는데 필수적인 알고리즘이다.
제약 충족 문제란 수많은 제약 조건(Constraints)을 충족하는 상태(States)를 찾아내는 수학문제를 일컫는다.
백준 6603 로또
집합 S에서 6개의 수를 고르는데(조합) DFS를 사용하되 깊이 제한으로 6일때 결과 값을 도출한다.