Simplifique seu fluxo de trabalho: Pesquise miniwebtool.
Adicionar
Página Inicial > Matemática > Operações matemáticas avançadas > Solucionador do Caixeiro Viajante (TSP)
 

Solucionador do Caixeiro Viajante (TSP)

Encontre a rota mais curta que visita cada cidade exatamente uma vez e retorna ao início. Programação dinâmica exata (Held-Karp) para instâncias pequenas e heurísticas de vizinho mais próximo + 2-opt para instâncias maiores. Aceita coordenadas ou uma matriz de distância e renderiza um tour animado em SVG.

Solucionador do Caixeiro Viajante (TSP)
Linhas de coordenadas: A, 10, 20 ou 10 20. Linhas da matriz: 0 10 15 20 — uma linha por vez, quadrada, não negativa. Máx 40 cidades.
Etiquetas separadas por vírgula ou espaço, uma por linha da matriz. Padrão A, B, C… se omitido.

Embed Solucionador do Caixeiro Viajante (TSP) Widget

Solucionador do Caixeiro Viajante (TSP)

O Solucionador do Caixeiro Viajante é uma calculadora prática e educativa para o clássico Problema do Caixeiro Viajante (TSP): dado um conjunto de cidades e distâncias entre pares, encontre a rota mais curta possível que visite cada cidade exatamente uma vez e retorne ao início. Este solucionador aceita coordenadas planas ou uma matriz de distância personalizada, seleciona o melhor algoritmo automaticamente com base no tamanho do problema e renderiza a rota resultante como um mapa SVG animado.

O Que é o Problema do Caixeiro Viajante?

Formalmente, dado um grafo ponderado completo G = (V, E) com conjunto de vértices V = {1, 2, ..., n} e pesos de aresta d(i, j), o TSP busca uma permutação π dos vértices que minimize:

minimizar Σi=1n-1 d(π(i), π(i+1)) + d(π(n), π(1))

O termo final fecha o loop. O TSP é um dos problemas mais antigos e estudados em otimização combinatória — ele é NP-difícil no caso geral, o que significa que nenhum algoritmo conhecido resolve todas as instâncias em tempo polinomial. Apesar disso, ele aparece em inúmeras aplicações do mundo real: roteamento de veículos, perfuração de PCB, sequenciamento de DNA, rotas de coleta em armazéns, cronogramas de observação astronômica e até entrega de correspondência rural.

Como Funciona Este Solucionador

Programação Dinâmica Held–Karp (Exata)

Para instâncias pequenas (até 12 cidades), o solucionador calcula a rota comprovadamente ideal usando o algoritmo Held–Karp, publicado independentemente por Richard Bellman e Michael Held & Richard Karp em 1962. A recorrência chave, onde C(S, j) é o caminho mais curto do vértice 1 ao vértice j visitando exatamente o subconjunto S:

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

O custo da rota ideal é então minj [C({1,...,n}, j) + d(j, 1)]. O Held–Karp é executado em tempo O(2n · n²) e memória O(2n · n) — uma melhoria enorme sobre a força bruta n!, mas ainda exponencial. Após cerca de 20 cidades, a pegada de memória torna-se impraticável.

Vizinho Mais Próximo + 2-opt (Heurística)

Para instâncias maiores, o solucionador usa uma heurística de dois estágios. Primeiro, o Vizinho Mais Próximo constrói uma rota rápida caminhando gananciosamente para a cidade não visitada mais próxima de cada vértice inicial. O solucionador tenta muitos vértices iniciais e mantém a melhor rota. Em seguida, a busca local 2-opt melhora a rota removendo iterativamente duas arestas e reconectando os dois caminhos resultantes da única outra maneira possível:

Antes: ... a — b ... c — d ... Após troca 2-opt: ... a — c ... b — d ... Se d(a,c) + d(b,d) < d(a,b) + d(c,d) → aceitar troca, inverter a sub-rota b..c

Geometricamente, o 2-opt remove todos os "cruzamentos" na rota: quaisquer dois segmentos que se cruzam podem sempre ser descruzados para um comprimento total menor. O algoritmo para em um ótimo local onde nenhuma troca única ajuda, chamado de rota 2-ideal. Em instâncias euclidianas realistas, o 2-opt normalmente encontra rotas de 2 a 5% do valor ideal real em milissegundos.

Formatos de Entrada

Modo Coordenadas (x, y)

Uma cidade por linha. Cada linha é etiqueta, x, y — a etiqueta é opcional. O solucionador calcula distâncias euclidianas automaticamente e visualiza as cidades em suas posições reais.

A, 10, 20 B, 40, 70 C, 75, 30 Paris: 2.35, 48.86 10 20 ← etiqueta auto C1

Modo Matriz de distância

Uma matriz quadrada n × n de distâncias não negativas, uma linha por vez, valores separados por espaços ou vírgulas. As matrizes podem ser simétricas ou assimétricas — as assimétricas modelam ruas de mão única, preços de passagens aéreas com disponibilidade variável e viagens dependentes do vento. Opcionalmente, forneça etiquetas no campo Etiquetas da matriz.

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

Comparação de Algoritmos

Algoritmo Complexidade de tempo Memória Qualidade do resultado Tamanho prático
Força bruta O(n!) O(n) Ideal n ≤ 10
Held–Karp DP O(2n · n²) O(2n · n) Ideal n ≤ 20
Vizinho Mais Próximo O(n²) O(n) ~25% pior que o ideal n ≤ milhares
NN + 2-opt O(n² · passagens) O(n) ~2–5% pior que o ideal n ≤ centenas

Como Usar Este Solucionador

  1. Escolha um modo de entrada. Coordenadas se suas cidades tiverem posições (x, y) significativas; Matriz de distância se seus custos forem não euclidianos ou assimétricos.
  2. Cole ou digite seus dados. Uma cidade ou linha por vez. Clique em um botão de exemplo rápido acima do formulário para preencher um exemplo válido.
  3. Escolha o algoritmo. Deixe em Automático para o padrão correto: Held–Karp quando a instância for pequena o suficiente para a idealidade comprovável, NN + 2-opt caso contrário. Force um algoritmo específico se quiser comparar.
  4. Escolha fechado ou aberto. Uma rota fechada retorna ao início — o TSP tradicional. O modo de caminho aberto resolve o problema relacionado do Caminho Hamiltoniano, onde o vendedor termina em uma cidade diferente.
  5. Clique em Resolver. A página de resultados mostra o comprimento total da rota, um SVG animado do percurso (clique em "Replay da animação" para repetir), a sequência completa de cidades, um detalhamento por aresta e a matriz de distância com as arestas da rota destacadas.

Exemplo Prático

Considere cinco cidades — um retângulo mais um pico: A (0, 0), B (4, 0), C (4, 3), D (0, 3), E (2, 5). O solucionador retorna:

Aplicações no Mundo Real

Perguntas Frequentes

O que é o Problema do Caixeiro Viajante?

O Problema do Caixeiro Viajante (TSP) busca a rota mais curta possível que visite cada cidade exatamente uma vez e retorne à cidade de partida. É um dos problemas mais famosos em otimização combinatória e é NP-difícil no caso geral, o que significa que nenhum algoritmo conhecido resolve todas as instâncias em tempo polinomial.

O que é o algoritmo Held–Karp?

Held–Karp é um algoritmo de programação dinâmica que resolve o TSP exatamente em tempo O(2n · n²) e memória O(2n · n). É dramaticamente mais rápido que a força bruta (n fatorial), mas ainda exponencial, portanto, na prática, é usado apenas para instâncias de até cerca de 20 cidades. Este solucionador usa Held–Karp quando há 12 cidades ou menos.

O que é o 2-opt e por que é usado?

O 2-opt é uma heurística de busca local que remove repetidamente duas arestas da rota atual e reconecta os dois caminhos resultantes da outra maneira possível. Quando a nova rota é mais curta, a troca é mantida. O 2-opt é executado em tempo polinomial por iteração e consistentemente encontra rotas a poucos pontos percentuais da ideal, por isso é a heurística clássica para instâncias maiores de TSP.

Quando devo usar coordenadas versus uma matriz de distância?

Use coordenadas quando suas cidades estiverem em um plano com distâncias em linha reta — por exemplo, pontos em um mapa, locais de armazéns ou furos em uma placa de circuito. Use uma matriz de distância quando o custo entre os pares não for euclidiano — por exemplo, preços de passagens aéreas, tempos de viagem com tráfego, distâncias rodoviárias de mão única ou custos assimétricos. O modo matriz aceita quaisquer distâncias não negativas, mesmo as assimétricas.

A solução 2-opt é a ideal?

Não, o 2-opt retorna uma rota 2-ideal, o que significa que nenhum par único de arestas pode ser trocado para produzir uma rota mais curta. Este é um ótimo local e geralmente está a poucos pontos percentuais do ótimo global em instâncias bem comportadas, mas não há garantia de que seja o melhor global. Para uma rota comprovadamente ideal em instâncias pequenas, escolha Held–Karp.

Esta ferramenta suporta matrizes de distância assimétricas?

Sim. No modo Matriz de distância, você pode inserir qualquer matriz quadrada não negativa, incluindo as assimétricas onde D[i][j] difere de D[j][i]. Tanto Held–Karp quanto 2-opt lidam corretamente com matrizes assimétricas. Isso é útil para problemas de roteamento do mundo real com ruas de mão única, tráfego ou custos de voo dependentes do vento.

Leitura Adicional

Cite este conteúdo, página ou ferramenta como:

"Solucionador do Caixeiro Viajante (TSP)" em https://MiniWebtool.com/br/solucionador-do-caixeiro-viajante-tsp/ de MiniWebtool, https://MiniWebtool.com/

pela equipe miniwebtool. Atualizado: 21 de abr de 2026

Você também pode experimentar nosso Solucionador de Matemática AI GPT para resolver seus problemas de matemática através de perguntas e respostas em linguagem natural.

Outras ferramentas relacionadas:

Operações matemáticas avançadas:

Ferramentas em destaque:

Remover espaçosCalculadora de Número de ExpressãoCalculadora BináriaGerador de endereços MACGerador de Letras AleatóriasGerador de Código MorseCalculadora de Desvio Padrão RelativoGerador de Cartelas de BingoCalculadora de Compatibilidade AmorosaGerador de Cores Aleatóriaspesquisa-de-endereço-MACCalculadora de ProporçãoCalculadora de Desvio Padrão - Alta PrecisãoContador de linhas📅 Calculadora de DatasCalculadora de CombinaçãoClassificar NúmerosFormatador de TextoConversor de Hex para BinárioCalculadora de Número de DestinoCalculadora de Signo Solar, Lunar e Ascendente 🌞🌙✨Gerador de Caça-PalavrasDecodificador de Código MorseGerador de IMEI AleatórioCalculadora de número de anjoCalculadora de Média HarmônicaCalculadora de cálcio corrigidaCalculadora de MedianaCalculadora de Dia do Ano - Que Dia do Ano é Hoje?📅 Calculadora de Diferença entre DatasConversor de Pés e Polegadas em CentímetrosConversor Octal para DecimalGerador de Palavras Aleatórias em InglêsConversor de Binário para OctalRemover Linhas Vazias do TextoCalculadora de Variação PercentualPesquisa de ID de Usuário do InstagramGerador de Superpoder AleatórioConversor de Binário para HexExtrator de Imagem de VídeoConversor de kPa para psiRemover acentos do textoConversor de Octal para BinárioGerador de AnagramasGerador de Endereço Falso AleatórioGerador de Números da LoteriaGerador de Cartas de Baralho Aleatórioconversor de ppm para porcentagemCalculadora de 1RM (Repetição Máxima)Lista de Anos BissextosCalculadora OctalCalculadora de NumerologiaGerador de LabirintosCalculadora de Estratégia MartingaleCalculadora de bônusPesquisa de ID de Usuário do FacebookConversor de Tamanho de ArquivoFerramenta Online para Remover PontuaçãoCalculadora de Número de Desejo da AlmaCalculadora de Coeficiente de VariaçãoCalculadora de Erro PercentualConversor de Hexadecimal para OctalCalculadora de Retorno de SaturnoConversor de cm para Pés e PolegadasGerador de Personagem RPG AleatórioRandomizador de Nomes OnlineDivisor de ÁudioCalculadora de Número MestreCalculadora de Taxa de Crescimento PercentualCalculadora de Octal para HexadecimalCriador de Box Plot (Gráfico de Caixa)Adicionar Números de Linha ao TextoAnalisador de Endereço MACcalculadora-hba1cPrimeiros n Dígitos do PiCalculadora de Números ComplexosCalculadora HexDivisor de ImagensCalculadora de Média, Mediana e ModaCalculadora de Número do NomeCalculadora de raiz quadradaGerador de CriptogramaCalculadora de Log Base 10Calculadora de quociente e restanteConversor de Decimal para BinárioGerador de Aniversário AleatórioGerador de Embaralhar PalavrasGerador de Coordenadas AleatóriasCalculadora de IdadeGerador de Hora AleatóriaSelecionador de Filmes AleatórioConversor de endereço IP para binárioGerador de Nomes AleatóriosConversor de Libras para QuilogramasCalculadora de Log (Logaritmo)Conversor PSI para BarCalculadora de Média GeométricaCalculadora de EntropiaCalculadora de notação científicaConversor de Binário para DecimalVerificador de Caminho HamiltonianoSolucionador do Caixeiro Viajante (TSP)Solucionador de Programação LinearCalculadora de Inclusão-ExclusãoSolucionador de Relações de RecorrênciaCalculadora de Matriz de AdjacênciaCalculadora de Ordenação TopológicaCalculadora de Coloração de GrafosSimulador de Portas LógicasSolucionador de Mapa de Karnaugh (K-Map)Simplificador de Álgebra BooleanaCalculadora de Função de PartiçãoCalculadora de Raiz DigitalVerificador de Número de FibonacciCalculadora de Frações EgípciasCalculadora de Função de MöbiusVerificador da Conjectura de GoldbachVerificador de Primo de MersenneLocalizador de Primos GêmeosVerificador de Números AmigáveisVerificador de Número PerfeitoCalculadora de Exponenciação ModularCalculadora de Permutações com RepetiçãoCalculadora de Tamanho de EfeitoCalculadora de Risco RelativoCalculadora de Razão de ChancesCalculadora de Tabela de ContingênciaCalculadora do Teste Exato de FisherCalculadora de Correlação de Postos de SpearmanCalculadora de Distribuição BetaCalculadora de Distribuição de WeibullCalculadora de Distribuição ExponencialCalculadora de Distribuição GeométricaCalculadora de Distribuição Binomial NegativaCalculadora de Distribuição HipergeométricaCalculadora de Teste F e Distribuição FCalculadora do Teorema de BayesCalculadora de Polinômio CaracterísticoCalculadora de Potência de MatrizCalculadora de Decomposição de CholeskyCalculadora de Decomposição QRCalculadora de Diagonalização de MatrizCalculadora Regra de CramerCalculadora de Espaço ColunaCalculadora de Espaço NuloCalculadora de Ângulo Entre VetoresCalculadora de Vetor UnitárioCalculadora de Magnitude de VetorCalculadora de Produto VetorialCalculadora de Produto EscalarCalculadora de Multiplicação de MatrizesCalculadora de Matriz InversaCalculadora RREF (Forma Escalonada Reduzida)Calculadora do Método de NewtonCalculadora de Matriz JacobianaCalculadora de Integral de SuperfícieCalculadora de Integral de LinhaCalculadora de RotacionalCalculadora de DivergênciaCalculadora de Gradiente MultivariávelCalculadora de Otimização (Cálculo)Solucionador de Taxas RelacionadasCalculadora de Taxa de Variação InstantâneaCalculadora de Taxa Média de VariaçãoCalculadora de Soma de Séries InfinitasCalculadora de Teste de Convergência de SériesCalculadora de Séries de PotênciaCalculadora de Série de MaclaurinCalculadora da Regra de L'HôpitalCalculadora de Integral ImprópriaCalculadora da Regra de SimpsonCalculadora da Regra TrapezoidalCalculadora de Soma de RiemannGraficador de Curvas ParamétricasCalculadora de Superfície de RevoluçãoCalculadora de Volume de RevoluçãoCalculadora de Distância em Geometria CoordenadaCalculadora Fórmula de HeronCalculadora de Linha Tangente ao CírculoCalculadora de Bissetriz do ÂnguloCalculadora de Círculo Inscrito (Incírculo)Calculadora de Circunscrição (Circuncírculo)Calculadora de Distância do Grande CírculoCalculadora de Distância 3DCalculadora de TorusCalculadora de Tronco de ConeCalculadora de Área de Polígono IrregularCalculadora de Polígono RegularIdentificador de Seção CônicaCalculadora de HipérboleCalculadora de ParábolaCalculadora de Expansão do Teorema BinomialGerador do Triângulo de PascalCalculadora de Notação de Produto (Notação Pi)Calculadora de Notação Sigma (Somatório)Calculadora do Teorema da Raiz RacionalCalculadora da Regra dos Sinais de DescartesCalculadora de Linhas Paralelas e PerpendicularesCalculadora de Equação da RetaConversor de Forma Padrão para Forma ReduzidaCalculadora de Forma Ponto-InclinaçãoResolvedor de Sistema de Equações Não LinearesSolucionador de Equações RacionaisResolvedor de Equações LiteraisSolucionador de Equações TrigonométricasResolvedor de Equações ExponenciaisResolvedor de Equações LogarítmicasCalculadora de Equação QuárticaSolucionador de Equação CúbicaCalculadora de EstimativaConversor de Número para FraçãoGerador de Contagem SalteadaCalculadora de Taxa UnitáriaCalculadora de Teto e PisoCalculadora de Valor AbsolutoEncontrador de Padrões NuméricosGerador de Gráfico de Valor PosicionalCalculadora de Ordem das Operações (PEMDAS)Calculadora de Adição e Subtração LongaCalculadora de Multiplicação LongaGerador de Tabuada🎮 Conversor de Moeda de Jogo🎲 Calculadora de Probabilidade de Loot🎰 Calculadora de Pity Gacha⚔️ Calculadora de DPS🎮 Conversor de Sensibilidade de Jogos❄️ Calculadora de Dia de Neve🚚 Estimador de Custo de Mudança🔍 Verificador de Plágio📷 OCR / Imagem para Texto📈 Criador de Gráfico de Linha🥧 Criador de Gráfico de Pizza📊 Criador de Gráfico de Barras🔊 Gerador de Tom🖱️ Contador de CliquesBloco de Notas Online⬛ Calculadora de Proporção de Tela🌍 Calculadora de Pegada de Carbono👙 Calculadora de Tamanho de SutiãCalculadora de Tamanho de PneuCalculadora de Custo de Combustível💧 Calculadora de Ponto de Orvalho🌡️ Calculadora de Índice de Calor🌬️ Calculadora de Sensação Térmica do Vento⏰ Despertador Online⏰ Calculadora de Cartão de Ponto🕐 Conversor de Hora Militar⏱️ Calculadora de Horas⏱️ Cronômetro Online⏱️ Temporizador de Contagem Regressiva🌐 Conversor de Fuso HorárioCalculadora de CarpeteCalculadora de Muro de ContençãoCalculadora de Dimensionamento HVACCalculadora de IsolamentoCalculadora de PavimentaçãoCalculadora de VergalhãoCalculadora de MadeiraCalculadora de Metragem QuadradaCalculadora de Multiplicação CruzadaCalculadora de Resumo de Cinco NúmerosCalculadora de PercentilCalculadora de Distribuição NormalCalculadora de Valor PCalculadora de ProporçãoCalculadora de Completar o QuadradoCalculadora de ArredondamentoCalculadora de Divisão LongaCalculadora CientíficaTemporizador de Estudo PomodoroCalculadora de Algarismos SignificativosCalculadora de Nota de ProvaCalculadora de Média PonderadaCalculadora de Nota FinalCalculadora de NotasCalculadora de Frequência de RessonânciaCalculadora de ImpedânciaCalculadora de Decibéis (dB)Calculadora de Fator de PotênciaCalculadora de Constante de Tempo RCCalculadora de TransformadorCalculadora de Bitola de FioCalculadora de Timer 555Calculadora de CapacitorCalculadora de Resistores em ParaleloCalculadora de Divisor de TensãoCalculadora de Resistor para LEDConversor de Mol/Grama/PartículaCalculadora de TitulaçãoCalculadora de Ponto de EbuliçãoCalculadora de Fórmula EmpíricaCalculadora de Rendimento PercentualCalculadora de EstequiometriaBalanceador de Equações QuímicasCalculadora de DiluiçãoCalculadora de Cavalos de PotênciaCalculadora de TorqueCalculadora de Queda LivreCalculadora da Lei dos Gases IdeaisCalculadora de PressãoCalculadora de DensidadeCalculadora de Trabalho e PotênciaCalculadora de Energia PotencialCalculadora de Energia CinéticaCalculadora de Movimento de ProjétilCalculadora de MomentoCalculadora de VelocidadeCalculadora de AceleraçãoCalculadora de ForçaCalculadora de ROI de InfluenciadorCalculadora de ROASCalculadora de CTRVerificador de Nome de Usuário de Mídia SocialOtimizador de Horário de Postagem em Mídias SociaisCalculadora de ROI de Mídias SociaisCalculadora de Custos de Anúncios do FacebookCalculadora de Monetização do YouTube ShortsCalculadora de Ganhos do TwitchCalculadora de Tempo de Exibição do YouTubeConversor de Timestamp do Twitter/XEstatísticas do Canal do YouTubeCalculadora de Dinheiro do TikTokGuia de Tamanho de Imagem para Redes SociaisGerador de Fontes para InstagramContador de Caracteres Twitter/XSeletor de Comentários do YouTubeExtrator de Tags do YouTubeBaixador de Miniaturas do YouTubeEstimador de Ganhos do YouTube