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;

}

相关推荐
仰泳的熊猫7 小时前
题目2570:蓝桥杯2020年第十一届省赛真题-成绩分析
数据结构·c++·算法·蓝桥杯
无极低码10 小时前
ecGlypher新手安装分步指南(标准化流程)
人工智能·算法·自然语言处理·大模型·rag
软件算法开发10 小时前
基于海象优化算法的LSTM网络模型(WOA-LSTM)的一维时间序列预测matlab仿真
算法·matlab·lstm·一维时间序列预测·woa-lstm·海象优化
Thera77710 小时前
C++ 高性能时间轮定时器:从单例设计到 Linux timerfd 深度优化
linux·开发语言·c++
罗超驿11 小时前
独立实现双向链表_LinkedList
java·数据结构·链表·linkedlist
superior tigre11 小时前
22 括号生成
算法·深度优先
君义_noip12 小时前
信息学奥赛一本通 1952:【10NOIP普及组】三国游戏 | 洛谷 P1199 [NOIP 2010 普及组] 三国游戏
c++·信息学奥赛·csp-s
努力也学不会java12 小时前
【缓存算法】一篇文章带你彻底搞懂面试高频题LRU/LFU
java·数据结构·人工智能·算法·缓存·面试
旖-旎12 小时前
二分查找(x的平方根)(4)
c++·算法·二分查找·力扣·双指针