7-169 汉密尔顿回路 (25 分)

简介: 7-169 汉密尔顿回路 (25 分)

7-169 汉密尔顿回路 (25 分)


著名的“汉密尔顿(Hamilton)回路问题”是要找一个能遍历图中所有顶点的简单回路(即每个顶点只访问 1 次)。本题就要求你判断任一给定的回路是否汉密尔顿回路。


输入格式:


首先第一行给出两个正整数:无向图中顶点数 N(2<N≤200)和边数 M。随后 M 行,每行给出一条边的两个端点,格式为“顶点1 顶点2”,其中顶点从 1 到N 编号。再下一行给出一个正整数 K,是待检验的回路的条数。随后 K 行,每行给出一条待检回路,格式为:


n V1 V2 ⋯ Vn


其中 n 是回路中的顶点数,Vi 是路径上的顶点编号。


输出格式:


对每条待检回路,如果是汉密尔顿回路,就在一行中输出"YES",否则输出"NO"。


输入样例:


6 10
6 2
3 4
1 5
2 5
3 1
4 1
1 6
6 3
1 2
4 5
6
7 5 1 4 3 6 2 5
6 5 1 4 3 6 2
9 6 2 1 6 3 4 5 2 6
4 1 2 5 1
7 6 1 3 4 5 2 6
7 6 1 2 5 4 3 1


输出样例:


1. YES
2. NO
3. NO
4. NO
5. YES
6. NO


#include<iostream>
using namespace std;
int N ,M ,K ,n ,n1 ,n2 ,v ,start ,pre;
int link[201][201];
int main() {
    cin >> N >> M;
    for (int i = 0; i < M; ++i) {
        cin >> n1 >> n2;
        link[n1][n2] = link[n2][n1] = 1;
    }
    cin >> K;
    for (int j = 0; j < K; ++j) {
        cin >> n;
        //int flag = (n != N + 1) ,vis[201] = {0};
        int flag = 0 ,vis[201] = {0};
        if (n != N + 1) {
            flag  = 1;
        }
        for (int i = 0; i < n; ++i) {
            cin >> v;
            if (i == 0) 
                start = v;
            else if (!link[pre][v])
                flag = 1;
            if (vis[v] && (i != n - 1 || v != start))
                flag = 1;
            pre = v;
            vis[v] = 1;
        }
//         cout << (flag ? "NO" : "YES") << endl;
        if (flag) cout << "NO" << endl;
        else cout << "YES" << endl;
    }
    return 0;
}
目录
相关文章
|
3月前
论多段图的最短路径问题(我认为本质上还是暴力枚举法)
本文讨论了多段图最短路径问题的解决方法,认为本质上是使用暴力枚举法,通过逐步计算每个阶段点的最短距离来确定从起点到终点的最短路径。
51 1
论多段图的最短路径问题(我认为本质上还是暴力枚举法)
|
8月前
|
机器学习/深度学习 算法 测试技术
【单源最短路 图论】882. 细分图中的可到达节点
【单源最短路 图论】882. 细分图中的可到达节点
|
8月前
|
算法 前端开发
图中的最长环
图中的最长环
65 0
|
算法 异构计算
分层次的电路设计方法
⭐本专栏针对FPGA进行入门学习,从数电中常见的逻辑代数讲起,结合Verilog HDL语言学习与仿真,主要对组合逻辑电路与时序逻辑电路进行分析与设计,对状态机FSM进行剖析与建模。
135 0
分层次的电路设计方法
数字逻辑电路设计实验:计时器/奇数骑
数字逻辑电路设计实验:计时器/奇数骑
65 0
|
调度
L2-014 列车调度 (25 分)(二分)
L2-014 列车调度 (25 分)(二分)
187 0
L2-014 列车调度 (25 分)(二分)
|
存储 算法 C语言
6-1 最小生成树(普里姆算法) (10分)
6-1 最小生成树(普里姆算法) (10分)
6-1 最小生成树(普里姆算法) (10分)
|
Python
100道单选题,随机选,考够60分的概率有多高?
100道单选题,随机选,考够60分的概率有多高?
237 0
7-9 地下迷宫探索 (8 分)
7-9 地下迷宫探索 (8 分)
151 0
7-9 地下迷宫探索 (8 分)
|
算法
【每日一题Day38】LC882细分图中的可到达节点 | 图论
给你一个无向图(原始图),图中有 n 个节点,编号从 0 到 n - 1 。你决定将图中的每条边 细分 为一条节点链,每条边之间的新节点数各不相同。
109 0

热门文章

最新文章