资源简介
某推销员要从城市v1出发,访问其它城市v2,v3,…,v6各一次且仅一次,最后返回v1。D为各城市间的距离矩阵。
问:该推销员应如何选择路线,才能使总的行程最短?
代码片段和文件信息
//
// main.cpp
// DP_TSP_recur
//
// Created by yunglynn on 12-11-23.
// Copyright (c) 2012年 yunglynn. All rights reserved.
//
#include
using namespace std;
#define MAX 6
typedef struct _node_st
{
bool inPath;
int nextIndex;
_node_st():inPath(false)nextIndex(-1){};
}Node*NodePtr;
void printPath(Node* node);
int tsp(int beginIndexint endIndex);
int dis[MAX][MAX]={
0 10 20 30 40 50
12 0 18 30 25 21
23 19 0 5 10 15
34 32 4 0 8 16
45 27 11 10 0 18
56 22 16 20 12 0
};
Node p[MAX];
Node record[MAX - 1][MAX];
int flag = 0;
int main()
{
p[0].inPath = true;
int res = tsp(0 0);
printPath(record[flag]);
cout << res << endl;
return 0;
}
//表示从begin开始经过所有点后到达end的最小距离
int tsp(int beginIndexint endIndex)
{
int result = 0xFFFFFFF;
bool isLast = true;
int k = 0;
for(int i = 0; i < MAX; i ++)
{
if(i != beginIndex)
{
if(!p[i].inPath)
{
- 上一篇:记账软件源代码——自己编的C++实现
- 下一篇:vc6.0编写的SOM神经网络聚类
相关资源
- 国际象棋的qt源代码
- C++中头文件与源文件的作用详解
- C++多线程网络编程Socket
- VC++ 多线程文件读写操作
- 利用C++哈希表的方法实现电话号码查
- 移木块游戏,可以自编自玩,vc6.0编写
- C++纯文字DOS超小RPG游戏
- VC++MFC小游戏实例教程(实例)+MFC类库
- 连铸温度场计算程序(C++)
- 6自由度机器人运动学正反解C++程序
- Em算法(使用C++编写)
- libstdc++-4.4.7-4.el6.i686.rpm
- VC++实现CMD命令执行与获得返回信息
- 白话C++(全)
- C++标准库第1、2
- 大数类c++大数类
- C++语言编写串口调试助手
- c++素数筛选法
- C++ mqtt 用法
- 商品库存管理系统 C++ MFC
- c++ 多功能计算器
- C++17 In Detail
- 嵌入式QtC++编程课件
- 颜色识别形状识别STM103嵌入式代码
- c++ 邮件多附件群发
- c++ 透明代理(hookproxy)
- mfc 调用redis
- FTP客户端源码(c++)
- c++ 画图(14Qt-XPS)
- c++多边形交并差运算
评论
共有 条评论