1150 Travelling Salesman Problem

#include<iostream>

#include<set>

#include<vector>

using namespace std;

//定义全局变量

int n,m,k,e[300][300];

int ansid;//最短路径的查询编号

int ans=999999999;//最短路径初始化

void check(int index){

int sum=0;//路径总长度

int cnt;//当前路径包含的顶点数

int flag=1;//判断当前路径是否联通

cin>>cnt;

set<int>s;//用于记录路径中访问的不同顶点

vector<int>v(cnt);//存储路径中顶点的序列

//将顶点存入序列中

for(int i=0;i<cnt;i++){

cin>>v[i];

s.insert(v[i]);

}

//计算路径长度并存入集合

for(int i=0;i<cnt-1;i++){

//如果相邻节点之间没有边,则路径不连通

if(e[v[i]][v[i+1]]==0){

flag=0;

}

sum+=e[v[i]][v[i+1]];

}

//情况1:如果路径不连通

if(flag==0){

cout<<"Path "<<index<<": NA (Not a TS cycle)"<<endl;

}

//情况2:不是环或未访问所有顶点

else if(v[0]!=v[cnt-1]||s.size()!=n){

cout<<"Path "<<index<<": "<<sum<<" (Not a TS cycle)"<<endl;

}

//情况3:TS是环,但不是简单环

else if(cnt!=n+1){

cout << "Path " << index << ": " << sum << " (TS cycle)" << endl;

if(sum<ans){

ans=sum;

ansid=index;

}

}

//情况4:TS简单环

else{

cout << "Path " << index << ": " << sum << " (TS simple cycle)" << endl;

if(sum<ans){

ans=sum;

ansid=index;

}

}

}

int main(){

cin>>n>>m;

for(int i=0;i<m;i++){

int t1,t2,t;

cin>>t1>>t2>>t;

e[t1][t2]=e[t2][t1]=t;

}

cin>>k;

//逐条检查每条路径

for(int i=1;i<=k;i++){

check(i);

}

cout << "Shortest Dist(" << ansid << ") = " << ans << endl;

return 0;

}

相关推荐
会编程的土豆2 分钟前
【数据结构与算法】哈希表
数据结构·散列表
无敌昊哥战神2 分钟前
【算法与数据结构】深入浅出回溯算法:理论基础与核心模板(C/C++与Python三语解析)
c语言·数据结构·c++·笔记·python·算法
zore_c3 分钟前
【C++】基础语法(命名空间、引用、缺省以及输入输出)
c语言·开发语言·数据结构·c++·经验分享·笔记
輕華5 分钟前
OpenCV三大传统人脸识别算法:EigenFace、FisherFace与LBPH实战
人工智能·opencv·算法
akarinnnn6 分钟前
【DAY16】字符函数和字符串函数
c语言·数据结构·算法
草莓熊Lotso8 分钟前
Linux 线程深度剖析:线程 ID 本质、地址空间布局与 pthread 源码全解
android·linux·运维·服务器·数据库·c++
沐雪轻挽萤9 分钟前
2. C++17新特性-结构化绑定 (Structured Bindings)
java·开发语言·c++
_日拱一卒12 分钟前
LeetCode:螺旋矩阵
算法·leetcode·矩阵
Tairitsu_H16 分钟前
C语言:排序(二)
c语言·开发语言·算法
Robot_Nav17 分钟前
ThetaStar全局规划算法纯C++控制器详解
开发语言·c++·lazy_theta_star