작업 흐름 간소화: miniwebtool 검색.
추가
홈페이지 > 수학 관련 도구 > 고급 수학 연산 도구 > 외판원 문제 솔버 (TSP)
 

외판원 문제 솔버 (TSP)

모든 도시를 정확히 한 번씩 방문하고 출발지로 돌아오는 가장 짧은 경로를 찾습니다. 소규모 데이터는 Held-Karp 동적 계획법(DP)을 통해 정확한 해를 구하고, 대규모 데이터는 최근접 이웃(Nearest-Neighbor) 및 2-opt 휴리스틱을 사용합니다. 좌표 또는 거리 행렬 입력을 지원하며 애니메이션이 포함된 SVG 경로를 생성합니다.

외판원 문제 솔버 (TSP)
좌표 형식: A, 10, 20 또는 10 20. 행렬 형식: 0 10 15 20 — 한 줄에 한 행씩, 정사각, 비음수 값. 최대 40개 도시.
쉼표 또는 공백으로 구분된 라벨을 행렬 행 순서대로 입력하세요. 생략 시 기본값 A, B, C...가 사용됩니다.

Embed 외판원 문제 솔버 (TSP) Widget

외판원 문제 솔버 (TSP) 정보

외판원 문제 솔버는 고전적인 외판원 문제(Traveling Salesman Problem, TSP)를 위한 실용적이고 교육적인 계산기입니다. 외판원 문제란 여러 도시와 각 도시 사이의 거리가 주어졌을 때, 모든 도시를 정확히 한 번씩 방문하고 다시 출발지로 돌아오는 최단 경로를 찾는 문제입니다. 이 솔버는 평면 좌표 또는 사용자 정의 거리 행렬을 입력받아 문제 크기에 따라 자동으로 최적의 알고리즘을 선택하며, 결과 경로를 애니메이션 SVG 지도로 렌더링합니다.

외판원 문제란 무엇인가요?

형식적으로, 정점 집합 V = {1, 2, ..., n}과 간선 가중치 d(i, j)를 가진 완전 가중 그래프 G = (V, E)가 주어졌을 때, TSP는 다음을 최소화하는 정점의 순열 π를 찾습니다:

최소화: Σi=1n-1 d(π(i), π(i+1)) + d(π(n), π(1))

마지막 항은 루프를 닫는 역할을 합니다. TSP는 조합 최적화 분야에서 가장 오래되고 많이 연구된 문제 중 하나로, 일반적인 경우 NP-난해(NP-hard)에 속합니다. 이는 모든 사례를 다항 시간 내에 해결하는 알고리즘이 없음을 의미합니다. 그럼에도 불구하고 차량 경로 최적화, PCB 드릴링, DNA 시퀀싱, 창고 피킹 경로, 천체 관측 일정, 우편 배달 등 수많은 실무 분야에서 활용됩니다.

이 솔버의 작동 원리

Held–Karp 동적 프로그래밍 (정확한 해)

소규모 사례(최대 12개 도시)의 경우, 솔버는 1962년 Richard Bellman과 Michael Held 및 Richard Karp가 각각 독립적으로 발표한 Held–Karp 알고리즘을 사용하여 증명 가능한 최적 경로를 계산합니다. 핵심 점화식은 다음과 같습니다 (여기서 C(S, j)는 부분 집합 S를 방문하고 정점 1에서 정점 j로 가는 최단 경로임):

C(S, j) = mink ∈ S \ {j} [ C(S \ {j}, k) + d(k, j) ]

최적 경로 비용은 minj [C({1,...,n}, j) + d(j, 1)]이 됩니다. Held–Karp는 O(2n · n²)의 시간 복잡도와 O(2n · n)의 메모리를 사용합니다. 이는 브루트 포스 방식인 n!보다는 훨씬 개선된 것이지만 여전히 지수적입니다. 약 20개 도시를 넘어가면 메모리 사용량이 감당할 수 없을 정도로 커집니다.

Nearest-Neighbor + 2-opt (휴리스틱)

더 큰 사례의 경우 솔버는 2단계 휴리스틱을 사용합니다. 먼저 Nearest-Neighbor 알고리즘이 각 시작 정점에서 가장 가까운 미방문 도시를 탐욕적으로 선택하여 빠른 경로를 구축합니다. 솔버는 여러 시작 정점을 시도하여 가장 좋은 경로를 유지합니다. 그 후 2-opt 국소 탐색을 통해 두 개의 간선을 반복적으로 제거하고 결과 경로를 다른 방식으로 재연결하여 경로를 개선합니다:

변경 전: ... a — b ... c — d ... 2-opt 교체 후: ... a — c ... b — d ... 만약 d(a,c) + d(b,d) < d(a,b) + d(c,d) → 교체 승인, b..c 구간 경로 반전

기하학적으로 2-opt는 경로 내의 모든 "교차"를 제거합니다. 교차하는 두 세그먼트는 항상 교차하지 않게 재연결하여 전체 길이를 단축할 수 있습니다. 알고리즘은 더 이상 개선할 수 없는 국소 최적 상태(이를 2-최적 경로라 함)에서 멈춥니다. 실제 유클리드 사례에서 2-opt는 수 밀리초 내에 실제 최적해의 2~5% 이내인 경로를 찾아냅니다.

입력 형식

좌표 모드 (x, y)

한 줄에 하나의 도시를 입력합니다. 각 줄은 라벨, x, y 형식이며 라벨은 선택 사항입니다. 솔버는 유클리드 거리를 자동으로 계산하고 실제 위치에 도시를 시각화합니다.

A, 10, 20 B, 40, 70 C, 75, 30 Seoul: 126.97, 37.56 10 20 ← 자동 라벨링 C1

거리 행렬 모드

비음수 거리로 구성된 n × n 정사각 행렬을 입력합니다. 각 행은 한 줄씩 입력하며 값은 공백이나 쉼표로 구분합니다. 행렬은 대칭일 수도, 비대칭일 수도 있습니다. 비대칭 행렬은 일방통행로, 가용성에 따른 항공권 가격, 바람의 영향을 받는 이동 등을 모델링할 때 쓰입니다. '행렬 라벨' 필드에서 라벨을 별도로 제공할 수 있습니다.

0 10 15 20 10 0 35 25 15 35 0 30 20 25 30 0

알고리즘 비교

알고리즘 시간 복잡도 메모리 결과 품질 실용적 크기
브루트 포스 O(n!) O(n) 최적 n ≤ 10
Held–Karp DP O(2n · n²) O(2n · n) 최적 n ≤ 20
Nearest-Neighbor O(n²) O(n) 최적해보다 ~25% 나쁨 n ≤ 수천 개
NN + 2-opt O(n² · passes) O(n) 최적해보다 ~2–5% 나쁨 n ≤ 수백 개

솔버 사용 방법

  1. 입력 모드 선택: 도시가 유효한 (x, y) 위치를 가지면 '좌표'를, 비용이 비유클리드적이거나 비대칭이면 '거리 행렬'을 선택합니다.
  2. 데이터 입력: 한 줄에 한 도시 또는 한 행씩 입력합니다. 폼 위의 빠른 예제 버튼을 클릭하여 유효한 예시를 채워볼 수 있습니다.
  3. 알고리즘 선택: '자동'으로 두는 것이 좋습니다. 사례가 충분히 작으면 Held-Karp를, 그렇지 않으면 NN + 2-opt를 사용합니다. 비교를 위해 특정 알고리즘을 강제할 수도 있습니다.
  4. 폐쇄형 또는 개방형 선택: 폐쇄형 경로는 출발지로 다시 돌아오는 전통적인 TSP입니다. 개방형 경로는 외판원이 다른 도시에서 끝나는 관련 문제인 '해밀턴 경로' 문제를 해결합니다.
  5. 해결 클릭: 결과 페이지에는 총 경로 길이, 경로 애니메이션 SVG('애니메이션 재생'으로 다시 볼 수 있음), 전체 방문 순서, 간선별 상세 분석, 경로가 강조된 거리 행렬이 표시됩니다.

작업 예시

직사각형과 꼭대기로 구성된 5개 도시 A (0, 0), B (4, 0), C (4, 3), D (0, 3), E (2, 5)를 가정해 봅시다. 솔버 결과:

실세계 적용 사례

자주 묻는 질문

외판원 문제란 무엇인가요?

외판원 문제(Traveling Salesman Problem, TSP)는 모든 도시를 정확히 한 번 방문하고 다시 출발 도시로 돌아오는 최단 경로를 찾는 문제입니다. 조합 최적화의 대표적인 난제이며 일반적인 경우 NP-난해입니다.

Held–Karp 알고리즘이란 무엇인가요?

Held–Karp는 TSP를 정확하게 해결하는 동적 프로그래밍 알고리즘으로 시간 복잡도는 O(2n · n²)입니다. 브루트 포스보다 빠르지만 여전히 기하급수적이라 대략 20개 도시 이하일 때 주로 쓰입니다. 본 솔버는 12개 이하일 때 이 방식을 사용합니다.

2-opt란 무엇이며 왜 사용되나요?

2-opt는 두 개의 간선을 끊고 다르게 연결하여 경로를 개선하는 휴리스틱입니다. 계산이 빠르고 최적해에 근접한 결과를 내놓기 때문에 대규모 TSP에서 가장 널리 사용되는 표준 기법입니다.

언제 좌표 모드를 사용하고 언제 거리 행렬 모드를 사용하나요?

지도상의 점이나 회로 기판 구멍처럼 직선 거리가 중요한 경우 좌표를 사용하세요. 항공권 가격, 교통량이 포함된 시간, 일방통행 등 기하학적으로 설명되지 않는 비용이 있다면 거리 행렬을 사용하세요.

2-opt 솔루션이 항상 최적인가요?

아니요, 2-opt는 국소 최적해를 찾습니다. 결과가 최적에 매우 가깝긴 하지만 완벽한 최단 경로를 보장하지는 않습니다. 보장된 최적해가 필요하면 소규모 사례에서 Held-Karp를 선택하십시오.

이 도구는 비대칭 거리 행렬을 지원하나요?

네. 비대칭 행렬을 지원하며 Held-Karp와 2-opt 모두 비대칭 비용을 정확하게 계산합니다. 이는 일방통행로나 기류의 영향을 받는 항공편 등 실무적인 경로 문제에 유용합니다.

더 읽어보기

이 콘텐츠, 페이지 또는 도구를 다음과 같이 인용하세요:

"외판원 문제 솔버 (TSP)" - https://MiniWebtool.com/ko/외판원-문제-솔버-tsp/에서 MiniWebtool 인용, https://MiniWebtool.com/

miniwebtool 팀 제작. 업데이트: 2026년 4월 21일

또한 저희의 AI 수학 해결사 GPT를 사용하여 자연어 질문과 답변으로 수학 문제를 해결할 수 있습니다.

기타 관련 도구:

고급 수학 연산 도구:

주요 도구:

인스타그램 사용자 ID 조회방어율 계산기상대 표준 편차 계산기애너그램 생성기16진수 변환기랜덤 이름 생성기16진수에서 10진수로 변환기WAR 계산기공백 제거분수에서 소수로 계산기CAGR 계산기소인수분해 계산기줄 바꿈 추가신뢰 구간 계산기cm에서 피트와 인치로 변환기OPS 계산기내 행운의 숫자는?월경주기 계산기파운드→킬로그램 변환기시저 암호 도구10진수를 16진수로 변환최대 공약수 계산기최소공배수 계산기로마-숫자-변환기소수 검사기줄 바꿈 제거이닝당 적중률(WHIP) 계산기백분율 오류 계산기이미지 분할기무작위 초능력 생성기사랑 궁합 계산기피트 인치 센티미터 변환기FPS 변환기복리 계산기랜덤 영어 단어 생성기러닝 페이스 계산기기울기 및 경사 계산기kg에서 파운드로 변환기야구 배팅 계산기몫과 나머지 계산기랜덤 생일 생성기비디오 이미지 추출기십진수에서 이진수로 변환기무작위 문자열 생성기MAC-주소-조회수면 계산기Hex-계산기이진 계산기확률 분포 계산기🎮 게임 감도 변환기이진수를 십진수로 변환계단 계산기암호화폐 레버리지 계산기잘고 텍스트 생성기변화율 계산기백분율 증가 계산기배당 수익률 계산기칼로리 소모 계산기다항식 전개 계산기분수 백분율 변환기분수 계산기무작위 토너먼트 대진표 생성기비트-계산기모스 부호 생성기즉시 연금 계산기매출총이익 계산기근무 시간 계산기기대 수명 계산기빗변 계산기아크코사인 (Arccos) 계산기PSI에서 bar로 변환기출루율 계산기마라톤 페이스 계산기야구 장타율 계산기FIP 계산기📅 날짜 계산기1RM (1회 최대 반복) 계산기혈당 변환기연중 일수 계산기 - 오늘은 올해의 몇 번째 날인가요중앙값 계산기카페인 과다복용 계산기ppm에서 퍼센트 변환기랜덤 그룹 생성기난수 선택기초과 근무 수당 계산기Z 점수 계산기표준 오차 계산기아크탄젠트 계산기퍼센트 감소 계산기유효숫자 계산기atan2 계산기퍼센트에서 PPM으로 변환기자동차 감가상각 계산기바코드 생성기공학용 계산기로그 베이스 2 계산기속도 변환기온라인 문장 부호 제거 도구분수 계산기해밀턴 경로 검사기 (Hamiltonian Path Checker)외판원 문제 솔버 (TSP)선형 계획법 솔버포함배제 계산기점화식 솔버인접 행렬 계산기위상 정렬 계산기그래프 채색 계산기논리 게이트 시뮬레이터카르노 맵 (K-Map) 솔버불 대수 간소화기분할 함수 계산기디지털 루트 계산기피보나치 수 검사기이집트 분수 계산기뫼비우스 함수 계산기골드바흐 추측 검증기메르센 소수 체커쌍둥이 소수 찾기친화수 검사기완전수 검사기모듈러 거듭제곱 계산기중복순열 계산기효과 크기 계산기상대위험도 계산기오즈비 계산기분할표 계산기피셔 정확 검정 계산기스피어만 순위 상관 계수 계산기베타 분포 계산기와이블 분포 계산기지수 분포 계산기기하 분포 계산기음이항분포 계산기초기하 분포 계산기F-검정 / F-분포 계산기베이즈 정리 계산기특성 다항식 계산기행렬 거듭제곱 계산기촐레스키 분해 계산기QR 분해 계산기행렬 대각화 계산기크라메르 법칙 계산기열공간 계산기영공간 계산기벡터 사이의 각도 계산기단위 벡터 계산기벡터 크기 계산기벡터 외적 계산기내적 계산기행렬 곱셈 계산기역행렬 계산기RREF 계산기 (행 사다리꼴)뉴턴 방법 계산기야코비 행렬 계산기면적분 계산기선적분 계산기cURL 계산기발산 계산기그래디언트 계산기 (다변수)최적화 계산기 (미적분)관련 변화율 계산기순간 변화율 계산기평균 변화율 계산기무한 급수 합 계산기급수 수렴 판정 계산기거듭제곱 급수 계산기매클로린 급수 계산기로피탈의 정리 계산기이상적분 계산기심프슨 법칙 계산기사다리꼴 공식 계산기리만 합 계산기매개변수 곡선 그래프 도구회전체 표면적 계산기회전체 부피 계산기좌표기하 거리 계산기헤론의 공식 계산기원의 접선 계산기각의 이등분선 계산기내접원 계산기외접원 계산기대권 거리 계산기3D 거리 계산기토러스 계산기원뿔대 계산기불규칙 다각형 면적 계산기정다각형 계산기원뿔 곡선 식별기쌍곡선 계산기포물선 계산기이항정리 전개 계산기파스칼의 삼각형 생성기곱 표기법 계산기 (Pi Notation)시그마 표기법 계산기 (합산)유리근 정리 계산기데카르트 부호 법칙 계산기평행선 및 수직선 계산기직선의 방정식 계산기표준형에서 기울기 절편형 변환기점 기울기 형태 계산기비선형 연립방정식 풀이기유리 방정식 풀이문자 방정식 풀이기삼각 방정식 풀이기지수 방정식 풀이기로그 방정식 풀이기사차방정식 계산기삼차방정식 풀이기어림 계산기숫자 분수 변환기건너뛰기 세기 생성기단위 요금 계산기천장 함수와 바닥 함수 계산기절댓값 계산기숫자 패턴 찾기자릿값 차트 생성기연산 순서 계산기 (PEMDAS)세로 덧셈 뺄셈 계산기긴 곱셈 계산기구구단표 생성기🎮 게임 화폐 변환기🎲 드롭 확률 계산기🎰 가챠 천장 계산기⚔️ DPS 계산기❄️ 눈 오는 날 계산기🚚 이사 비용 계산기🔍 표절 검사기📷 OCR / 이미지에서 텍스트 추출📈 꺾은선 그래프 만들기🥧 파이 차트 메이커📊 막대 그래프 만들기🔊 톤 생성기🖱️ 클릭 카운터온라인 메모장⬛ 화면 비율 계산기🌍 탄소 발자국 계산기👙 브라 사이즈 계산기타이어 크기 계산기연료비 계산기💧 이슬점 계산기🌡️ 열지수 계산기🌬️ 체감 온도 계산기⏰ 온라인 알람 시계⏰ 타임카드 계산기📅 날짜 차이 계산기🕐 군사 시간 변환기⏱️ 시간 계산기⏱️ 온라인 스톱워치⏱️ 카운트다운 타이머🌐 시간대 변환기카펫 계산기옹벽 계산기HVAC 용량 계산기단열재 계산기포장재 계산기철근 계산기목재 계산기평방피트 계산기교차 곱셈 계산기다섯 수 요약 계산기백분위수 계산기정규분포 계산기p-Value 계산기비율 계산기完全平方式 계산기반올림 계산기긴 나눗셈 계산기포모도로 공부 타이머시험 점수 계산기가중 성적 계산기최종 성적 계산기성적 계산기공진 주파수 계산기임피던스 계산기데시벨(dB) 계산기역률 계산기RC 시정수 계산기변압기 계산기전선 게이지 계산기555 타이머 계산기커패시터 계산기병렬 저항 계산기전압 분배기 계산기LED 저항기 계산기몰/그램/입자 변환기적정 계산기끓는점 계산기실험식 계산기수율 계산기화학양론 계산기화학 반응식 균형 계산기희석 계산기마력 계산기토크 계산기자유 낙하 계산기이상 기체 법칙 계산기압력 계산기밀도 계산기일과 일률 계산기위치 에너지 계산기운동 에너지 계산기포물선 운동 계산기운동량 계산기속도 계산기가속도 계산기힘 계산기인플루언서 ROI 계산기ROAS 계산기CTR 계산기소셜 미디어 사용자 이름 확인기소셜 미디어 게시 시간 최적화 도구Social Media ROI 계산기Facebook 광고 비용 계산기YouTube 쇼츠 수익화 계산기Twitch 수익 계산기YouTube 시청 시간 계산기Twitter/X 타임스탬프 변환기YouTube 채널 통계TikTok 수익 계산기소셜 미디어 이미지 크기 가이드Instagram 폰트 생성기Twitter/X 글자수 카운터YouTube 댓글 추첨기YouTube 태그 추출기YouTube 썸네일 다운로더유튜브 수익 추정기무작위 RPG 캐릭터 생성기