九度oj 题目1109:连通图
- 题目描述:
-
给定一个无向图和其中的所有边,判断这个图是否所有顶点都是连通的。
- 输入:
-
每组数据的第一行是两个整数 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:连通图的更多相关文章
- 九度oj题目&吉大考研11年机试题全解
九度oj题目(吉大考研11年机试题全解) 吉大考研机试2011年题目: 题目一(jobdu1105:字符串的反码). http://ac.jobdu.com/problem.php?pid=11 ...
- 九度OJ 题目1384:二维数组中的查找
/********************************* * 日期:2013-10-11 * 作者:SJF0115 * 题号: 九度OJ 题目1384:二维数组中的查找 * 来源:http ...
- hdu 1284 关于钱币兑换的一系列问题 九度oj 题目1408:吃豆机器人
钱币兑换问题 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Sub ...
- 九度oj 题目1007:奥运排序问题
九度oj 题目1007:奥运排序问题 恢复 题目描述: 按要求,给国家进行排名. 输入: 有多组数据. 第一行给出国家数N,要求排名的国家数M,国家号 ...
- 九度oj 题目1087:约数的个数
题目链接:http://ac.jobdu.com/problem.php?pid=1087 题目描述: 输入n个整数,依次输出每个数的约数的个数 输入: 输入的第一行为N,即数组的个数(N<=1 ...
- 九度OJ题目1105:字符串的反码
tips:scanf,cin输入字符串遇到空格就停止,所以想输入一行字符并保留最后的"\0"还是用gets()函数比较好,九度OJ真操蛋,true?没有这个关键字,还是用1吧,还是 ...
- 九度oj题目1009:二叉搜索树
题目描述: 判断两序列是否为同一二叉搜索树序列 输入: 开始一个数n,(1<=n<=20) 表示有n个需要判断,n= 0 的时候输入结束. 接 ...
- 九度oj题目1002:Grading
//不是说C语言就是C++的子集么,为毛printf在九度OJ上不能通过编译,abs还不支持参数为整型的abs()重载 //C++比较正确的做法是#include<cmath.h>,cou ...
- 九度OJ题目1003:A+B
while(cin>>str1>>str2)就行了,多简单,不得不吐槽,九度的OJ真奇葩 题目描述: 给定两个整数A和B,其表示形式是:从个位开始,每三位数用逗号", ...
随机推荐
- git与GitHub(一)
相信,很多初入前端者都会对git以及GitHub不太了解,而我当时也经历过各种面试大关,也都会问:你了解git和GitHub吗?那么今天先来说一说git. 那么什么是git? (以下转载自廖雪峰老师的 ...
- 使用vscode软件运行zebrajs框架小结
最近在研究使用zebrajs框架,用vscode编辑器进行开发.vsc这个编辑器说起来还是很强大的,就是支持各种系统的多种语言开发.用于前端的话可以直接在编辑器上边调试javascript,就是需要n ...
- 基于Myeclipse的三大框架(SSH)整合
文中主要基于Myeclipse进行配置,配置流程为:Hibernate --> Spring --> 整合 --> struts2 -->整合.注意:在此文中,主要讲述基于注解 ...
- MD5 介绍
MD5(单向散列算法)的全称是Message-Digest Algorithm 5(信息-摘要算法),经MD2.MD3和MD4发展而来.MD5算法的使用不需要支付任何版权费用. MD5功能: 输入任意 ...
- 迅为iMX6Q/PLUS开发板烧写设备树内核 Qt 系统
迅为iMX6Q 和 iMX6PLUS 两个硬件版本,设备树镜像的烧写方法以及镜像所在目录,镜像名称全部一致. 如果用的是 iMX6Q 版本,想要烧写设备树版本镜像,请使用 iMX6Q 设备树版本的光盘 ...
- Entity Framework插入数据报错:Validation failed for one or more entities
www.111cn.net 编辑:lanve 来源:转载 今天在处理Entity Framework插入数据库时,报错: Validation failed for one or more entit ...
- House of Spirit(fastbin)
0x01 fastbin fastbin所包含chunk的大小为16 Bytes, 24 Bytes, 32 Bytes, … , 80 Bytes.当分配一块较小的内存(mem<=64 Byt ...
- 实现类似AOP的封装和配置
这是张孝祥老师Java进阶讲解中最后一个视频,就是实现类似spring中的AOP的封装和配置,特别特别小型的一个框架雏形,但是spring中的核心思想还是体现出来了,真的厉害,张老师!!! 一.重点知 ...
- Web服务器☞Apache VS Nginx
Web服务器☞Apache VS Nginx LZ最近公司有一个项目在Web服务器选型上,在Apache和Nginx之间引起了一些讨论.这两者目前都是业内优秀的web服务器,都实现了HTTP1.1协议 ...
- iterator方法和for方法 遍历数据库user表结果集ResultSet
首先,把连接数据库的语句做成工具类,因为会一直用到这几句 代码如下: package com.swift.jdbc; import java.sql.Connection; import java.s ...