题目描述:

给定一个无向图和其中的所有边,判断这个图是否所有顶点都是连通的。

输入:

每组数据的第一行是两个整数 n 和 m(0<=n<=1000)。n 表示图的顶点数目,m 表示图中边的数目。如果 n 为 0 表示输入结束。随后有 m 行数据,每行有两个值 x 和 y(0<x, y <=n),表示顶点 x 和 y 相连,顶点的编号从 1 开始计算。输入不保证这些边是否重复。

输出:

对于每组输入数据,如果所有顶点都是连通的,输出"YES",否则输出"NO"。

样例输入:
4 3
1 2
2 3
3 2
3 2
1 2
2 3
0 0
样例输出:
NO
YES 这个题一开始用深度优先搜索做的,代码如下
 #include <cstdio>
#include <cstdlib>
#include <cstring> int map[][];
int flag[];
int n, m; void dfs(int k) {
flag[k] = ;
for(int i = ; i <= n; i++) {
if(flag[i] == && map[k][i] == ) {
dfs(i);
}
}
} int main(int argc, char const *argv[])
{
//freopen("input.txt","r",stdin);
while(scanf("%d %d",&n,&m) != EOF && n != ) {
memset(map,, sizeof(map));
memset(flag, , sizeof(flag)); while(m--) {
int a, b;
scanf("%d %d",&a, &b);
map[a][b] = map[b][a] = ;
}
flag[] = ;
dfs();
bool isOk = true;
for(int i = ; i <=n; i++) {
if(flag[i] == ) {
isOk = false;
break;
}
}
if(isOk) {
puts("YES");
}
else {
puts("NO");
} }
return ;
}

但耗时略长,内存占用略大

后来试了试迪杰特斯拉算法的变形

 #include <cstdio>
#include <cstdlib>
#include <cstring> int map[][];
int flag[];
int n, m; void dfs(int k) {
flag[k] = ;
for(int i = ; i <= n; i++) {
if(flag[i] == && map[k][i] == ) {
dfs(i);
}
}
} int main(int argc, char const *argv[])
{
freopen("input.txt","r",stdin);
while(scanf("%d %d",&n,&m) != EOF && n != ) {
memset(map,, sizeof(map));
memset(flag, , sizeof(flag)); while(m--) {
int a, b;
scanf("%d %d",&a, &b);
map[a][b] = map[b][a] = ;
}
flag[] = ; for(int i = ; i <= n; i++) {
for(int j = ; j <= n; j++) {
if(flag[j] == && map[][j] == ) {
flag[j] = ;
for(int k = ; k <= n; k++) {
if(map[j][k] == ) {
map[][k] = ;
}
}
}
}
} bool isOk = true;
for(int i = ; i <=n; i++) {
if(flag[i] == ) {
isOk = false;
break;
}
}
if(isOk) {
puts("YES");
}
else {
puts("NO");
} }
return ;
}

但耗时更长

也试了试flyod算法

 #include <cstdio>
#include <cstdlib>
#include <cstring> int map[][];
int n, m; int main(int argc, char const *argv[])
{
//freopen("input.txt","r",stdin);
while(scanf("%d %d",&n,&m) != EOF && n != ) {
memset(map,, sizeof(map)); while(m--) {
int a, b;
scanf("%d %d",&a, &b);
map[a][b] = map[b][a] = ;
}
map[][] = ;
for(int i = ; i <= n; i++) {
for(int j = ; j <= n; j++) {
for(int k = ; k <= n; k++) {
if(map[j][i] == && map[i][k] == ) {
map[j][k] = ;
}
}
}
} bool isOk = true;
for(int i = ; i <=n; i++) {
if(map[][i] == ) {
isOk = false;
break;
}
}
if(isOk) {
puts("YES");
}
else {
puts("NO");
} }
return ;
}

直接超时了

突然会想起一个月前做的题,好像叫做并查集的东西,代码如下

 #include <cstdio>
#include <cstdlib>
#include <cstring> int next[];
int n, m; int find(int t) {
while(next[t] != ) {
t = next[t];
}
return t;
} int main(int argc, char const *argv[])
{
//freopen("input.txt","r",stdin);
while(scanf("%d %d",&n,&m) != EOF && n != ) {
memset(next, , sizeof(next)); while(m--) {
int a, b;
scanf("%d %d",&a, &b);
int fa = find(a);
int fb = find(b);
if(fa != fb) {
next[fa] = b;
}
} int isOk = ;
for(int i = ; i <= n; i++) {
if(next[i] == ) {
isOk++;
if(isOk >= ) {
puts("NO");
break;
}
}
}
if(isOk == ) {
puts("YES");
} }
return ;
}

耗时和内存都有质的飞跃,但如何再进一步优化呢?

九度oj 题目1109:连通图的更多相关文章

  1. 九度oj题目&amp;吉大考研11年机试题全解

    九度oj题目(吉大考研11年机试题全解) 吉大考研机试2011年题目: 题目一(jobdu1105:字符串的反码).    http://ac.jobdu.com/problem.php?pid=11 ...

  2. 九度OJ 题目1384:二维数组中的查找

    /********************************* * 日期:2013-10-11 * 作者:SJF0115 * 题号: 九度OJ 题目1384:二维数组中的查找 * 来源:http ...

  3. hdu 1284 关于钱币兑换的一系列问题 九度oj 题目1408:吃豆机器人

    钱币兑换问题 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Sub ...

  4. 九度oj 题目1007:奥运排序问题

    九度oj 题目1007:奥运排序问题   恢复 题目描述: 按要求,给国家进行排名. 输入:                        有多组数据. 第一行给出国家数N,要求排名的国家数M,国家号 ...

  5. 九度oj 题目1087:约数的个数

    题目链接:http://ac.jobdu.com/problem.php?pid=1087 题目描述: 输入n个整数,依次输出每个数的约数的个数 输入: 输入的第一行为N,即数组的个数(N<=1 ...

  6. 九度OJ题目1105:字符串的反码

    tips:scanf,cin输入字符串遇到空格就停止,所以想输入一行字符并保留最后的"\0"还是用gets()函数比较好,九度OJ真操蛋,true?没有这个关键字,还是用1吧,还是 ...

  7. 九度oj题目1009:二叉搜索树

    题目描述: 判断两序列是否为同一二叉搜索树序列 输入:                        开始一个数n,(1<=n<=20) 表示有n个需要判断,n= 0 的时候输入结束. 接 ...

  8. 九度oj题目1002:Grading

    //不是说C语言就是C++的子集么,为毛printf在九度OJ上不能通过编译,abs还不支持参数为整型的abs()重载 //C++比较正确的做法是#include<cmath.h>,cou ...

  9. 九度OJ题目1003:A+B

    while(cin>>str1>>str2)就行了,多简单,不得不吐槽,九度的OJ真奇葩 题目描述: 给定两个整数A和B,其表示形式是:从个位开始,每三位数用逗号", ...

随机推荐

  1. kickstart_2018_round_H_C Let Me Count The Ways

    思路: 容斥. 实现: #include <bits/stdc++.h> using namespace std; typedef long long ll; ; ; ll f[MAXN ...

  2. centos 7 安装JDK (Linux安装jdk)

    centos 7安装JDK (Linux安装jdk) 第一部分 首先查看centos 7是否有openjdk,如没有就跳过第一部分,直接第二部分. [master@bogon ~]$ java -ve ...

  3. java 设计模式 之 桥梁模式

    桥梁模式:将抽象和实现解耦,使两者可以独立的变化.解释:将两个有组合关系,强耦合的对象,各自抽象然后解耦.(类关系图看https://www.cnblogs.com/blogxiao/p/951388 ...

  4. codevs 3278 最小m 段和问题

    时间限制: 1 s  空间限制: 256000 KB  题目等级 : 黄金 Gold 题目描述 Description 给定 n 个整数(不一定是正整数)组成的序列,现在要求将序列分割为 m 段,每段 ...

  5. 如何在腾讯云上安装Cloud Foundry

    Cloud Foundry是VMware推出的业界第一个开源PaaS云平台,它支持多种框架.语言.运行时环境.云平台及应用服务,使开发人员能够在几秒钟内进行应用程序的部署和扩展,无需担心任何基础架构的 ...

  6. (转)MyBatis框架的学习(四)——Mapper.xml文件中的输入和输出映射以及动态sql

    http://blog.csdn.net/yerenyuan_pku/article/details/71893689 前面对MyBatis框架的学习中,我们对Mapper.xml映射文件多少有些了解 ...

  7. Tensorflow_入门学习_1

    1.0 TensorFlow graphs Tensorflow是基于graph based computation: 如: a=(b+c)∗(c+2) 可分解为 d=b+c e=c+2 a=d∗e ...

  8. kafka 安装以及测试

    1,下载kafka 并进行解压 http://mirrors.cnnic.cn/apache/kafka/0.8.1.1/kafka_2.9.2-0.8.1.1.tgz 2,启动Zookeeper  ...

  9. 【转】Python 访问 HDFS

    1.前言 hdfs , Hadoop Distributed File System.Hadoop的分布式文件系统,安全行和扩展性没得说. 访问HDFS的方式有以下几种: 命令行方式:FS Shell ...

  10. tomcat BIO 、NIO 、AIO

    11.11活动当天,服务器负载过大,导致部分页面出现了不可访问的状态.那后来主管就要求调优了,下面是tomcat bio.nio.apr模式以及后来自己测试的一些性能结果. 原理方面的资料都是从网上找 ...