博客
关于我
PAT---A1122 Hamiltonian Cycle
阅读量:635 次
发布时间:2019-03-14

本文共 1298 字,大约阅读时间需要 4 分钟。

题意

给出一个无向图, n个顶点(顶点id从1开始), m条边.

输入k组顶点集, 判断是否为Hamiltonian cycle.

Hamiltonian cycle: a simple cycle that contains every vertex in a graph.

思路

判断Hamiltonian cycle:

  • 该顶点集一定包含n+1个顶点
  • 首尾一定相等
  • 连通性检查

Sample Input:

6 106 23 41 52 53 14 11 66 31 24 567 5 1 4 3 6 2 56 5 1 4 3 6 29 6 2 1 6 3 4 5 2 64 1 2 5 17 6 1 3 4 5 2 67 6 1 2 5 4 3 1

Sample Output:

YESNONONOYESNO
#include "bits/stdc++.h"using namespace std;const int N = 210;int G[N][N];int main(){//     freopen("input.txt","r",stdin);    int n, m; cin >> n >> m;    for (int i = 0; i < m; ++i) {        int a, b; scanf("%d%d",&a,&b);        G[a][b] = G[b][a] = 1;    }    int k;  cin >> k;    for (int i = 0; i < k; ++i) {        int num;  scanf("%d",&num);        if (num != n+1) {            printf("NO\n");            string s; getline(cin,s);            continue;        }        vector
a(num); set
cnt; for (int j = 0; j < num; ++j) scanf("%d",&a[j]),cnt.insert(a[j]); if (a.back() != a.front() || cnt.size() != n) { printf("NO\n"); continue; } bool ok = true; for (int j = 1; j < num; ++j) { if (!G[a[j]][a[j-1]]) { ok = false; break; } } if (ok) printf("YES\n"); else printf("NO\n"); }}

转载地址:http://bzhoz.baihongyu.com/

你可能感兴趣的文章
Nginx代理配置详解
查看>>
Nginx代理静态资源(gis瓦片图片)实现非固定ip的url适配网络环境映射ip下的资源请求解决方案
查看>>
Nginx代理静态资源(gis瓦片图片)实现非固定ip的url适配网络环境映射ip下的资源请求解决方案
查看>>
nginx优化日志拒绝特定404请求写入
查看>>
Nginx优化解析
查看>>
Nginx使用proxy_cache指令设置反向代理缓存静态资源
查看>>
Nginx做反向代理时访问端口被自动去除
查看>>
Nginx入门教程-简介、安装、反向代理、负载均衡、动静分离使用实例
查看>>
Nginx入门简介和反向代理、负载均衡、动静分离理解
查看>>
nginx入门篇----nginx服务器基础配置
查看>>
nginx反向代理
查看>>
Nginx反向代理
查看>>
nginx反向代理、文件批量改名及统计ip访问量等精髓总结
查看>>
Nginx反向代理与正向代理配置
查看>>
Nginx反向代理及负载均衡实现过程部署
查看>>
Nginx反向代理和负载均衡部署指南
查看>>
Nginx反向代理是什么意思?如何配置Nginx反向代理?
查看>>
nginx反向代理解决跨域问题,使本地调试更方便
查看>>
nginx反向代理转发、正则、重写、负摘均衡配置案例
查看>>
Nginx反向代理配置
查看>>