原创


标题:发现环

小明的实验室有N台电脑,编号1~N。原本这N台电脑之间有N-1条数据链接相连,恰好构成一个树形网络。在树形网络上,任意两台

电脑之间有唯一的路径相连。

不过在最近一次维护网络时,管理员误操作使得某两台电脑之间增加了一条数据链接,于是网络中出现了环路。环路上的电脑由于两

两之间不再是只有一条路径,使得这些电脑上的数据传输出现了BUG。

为了恢复正常传输。小明需要找到所有在环路上的电脑,你能帮助他吗?

输入
-----
第一行包含一个整数N。
以下N行每行两个整数a和b,表示a和b之间有一条数据链接相连。

对于30%的数据,1 <= N <= 1000
对于100%的数据, 1 <= N <= 100000, 1 <= a, b <= N

输入保证合法。

输出
----
按从小到大的顺序输出在环路上的电脑的编号,中间由一个空格分隔。

样例输入:
5
1 2
3 1
2 4
2 5
5 3

样例输出:
1 2 3 5

资源约定:
峰值内存消耗 < 256M
CPU消耗 < 1000ms

请严格按要求输出,不要画蛇添足地打印类似:“请您输入...” 的多余内容。

所有代码放在同一个源文件中,调试通过后,拷贝提交该源码。

注意: main函数需要返回0
注意: 只使用ANSI C/ANSI C++ 标准,不要调用依赖于编译环境或操作系统的特殊函数。
注意: 所有依赖的函数必须明确地在源文件中 #include <xxx>, 不能通过工程设置而省略常用头文件。

提交时,注意选择所期望的编译器类型。

本人解题思路:

主要还是要用到 DFS ;目的是在一棵树中,找到一个环路;假定选择在环路中的A结点作为环路的起点,则A结点也可以作为环

路的终点,由于不知哪个结点在环路中,要依次枚举结点 1~N;

假设用户输入的数据为:

1 2 (0)

1 3 (0)

2 4 (0)

2 5 (0)

5 6 (0)

5 7 (0)

6 7 (0)

第三列的(0/1/-1)数码的意义:

0 :此边未遍历

-1:此边经判断不在环上

1:此边在环上

在上图中,5-6-7组成环,现在从结点1(以结点1为起点和终点)开始遍历每条边(边的遍历顺序与用户输入的边的顺序有关);

在遍历过程中只有回到起点时,遍历结束。

搜索用户输入的N行数据,找到有数码1的某行(例子中为第1行),先将此行第三列的数码置1(代表遍历过),再以此行的另

一个结点(例子中为2)为起点,搜索N行数据中数码位为0的行数据(1代表遍历过),停留在第三行,将第三列数码位置1,再

以4为起点继续搜索,此时4为叶子结点,搜索数据未果,所以递归回来将 2 4 (1)——> 2 4 (-1)表示此边定不在环中;此时

再以2为起点继续搜索N行数据,停留在 2 5 (1);再以5为起点继续搜索,停留在 5 6(1),继续搜索停留在 6 7 (1),当停

留在 5 7 (1)的时候,虽然出现了环 5 - 6 - 7,但是不满足以 1 为终点,所以搜索失败(再以7为起点搜索未果);递归回来,

5 7 (-1); 6 7 (-1);5 6 (-1);2 5 (-1);继续以1为起点搜索......所以当以5为第一个起点搜索时,才会搜索成功。

#include<stdio.h>
#include<stdlib.h> int arr[][]={}; //分配3列
int N=;
int flag=; //flag==1 表示找到起点,返回
int unaccess=; void dfs(int num,int value){
int i=;
int j=;
for(i=;i<=N-;i++){
if(flag==){
break;
}
for(j=;j<=;j++){ //***************
if(i==N- && j== && arr[i][j]!=num){ //叶子结点
unaccess=;
break;
}
if(i==N- && j== && arr[i][j]==num){
if(arr[i][]==){ //叶子结点在第N行,这条边已经遍历过
unaccess=;
break;
}
}
//*************** if(arr[i][j]==num && arr[i][]==){
arr[i][]=; //***************
if(j==){
if(arr[i][]==value){ //判断是不是起点
flag=;
break;
}
}
else{
if(arr[i][]==value){
flag=;
break;
}
}
//*************** if(j==){
dfs(arr[i][],value);
if(flag==){
break;
}
if(unaccess==){
arr[i][]=-;
}
unaccess=;
}
else{
dfs(arr[i][],value);
if(flag==){
break;
}
if(unaccess==){
arr[i][]=-;
}
unaccess=;
}
} }
}
} int main(){
scanf("%d",&N); int i=;
int j=;
for(i=;i<=N-;i++){
for(j=;j<=;j++){
scanf("%d",&arr[i][j]);
}
} for(i=;i<=N-;i++){ //最后一列为0代表此边可以走
arr[i][]=;
} int num=;
for(num=;num<=N;num++){ // num代表起点和终点
dfs(num,num);
if(flag==){
break;
}
else{
for(int z=;z<=N-;z++){ //以新的起点继续dfs
arr[z][]=;
}
}
} int *RT; //此数组用来存放环中结点
RT=(int *)malloc(sizeof(int)*(N+));
for(i=;i<=N;i++){
RT[i]=;
} for(i=;i<=N-;i++){
if(arr[i][]==){
RT[arr[i][]]=;
RT[arr[i][]]=;
}
} for(i=;i<=N;i++){
if(RT[i]==){
printf("%d ",i);
}
}
free(RT);
return ;
}

有 错误 或 改良方法  欢迎提出。

12:49:48

2018-05-10

发现环——第八届蓝桥杯C语言B组(国赛)第四题的更多相关文章

  1. 希尔伯特曲线——第八届蓝桥杯C语言B组(国赛)第三题

    原创 标题:希尔伯特曲线 希尔伯特曲线是以下一系列分形曲线 Hn 的极限.我们可以把 Hn 看作一条覆盖 2^n × 2^n 方格矩阵的曲线,曲线上一共有 2^n × 2^n 个顶点(包括左下角起点和 ...

  2. 磁砖样式——第八届蓝桥杯C语言B组(国赛)第二题

    原创 标题:磁砖样式 小明家的一面装饰墙原来是 3*10 的小方格.现在手头有一批刚好能盖住2个小方格的长方形瓷砖.瓷砖只有两种颜色:黄色和橙色. 小明想知道,对于这么简陋的原料,可以贴出多少种不同的 ...

  3. 2017第八届蓝桥杯C/C++ B组省赛-日期问题

    标题:日期问题 小明正在整理一批历史文献.这些历史文献中出现了很多日期.小明知道这些日期都在1960年1月1日至2059年12月31日.令小明头疼的是,这些日期采用的格式非常不统一,有采用年/月/日的 ...

  4. 2017年第八届蓝桥杯C/C++B组省赛题目解析

    一. 购物单 小明刚刚找到工作,老板人很好,只是老板夫人很爱购物.老板忙的时候经常让小明帮忙到商场代为购物.小明很厌烦,但又不好推辞. 这不,XX大促销又来了!老板夫人开出了长长的购物单,都是有打折优 ...

  5. 2017第八届蓝桥杯C/C++ B组省赛-购物单

    标题: 购物单 小明刚刚找到工作,老板人很好,只是老板夫人很爱购物.老板忙的时候经常让小明帮忙到商场代为购物.小明很厌烦,但又不好推辞. 这不,XX大促销又来了!老板夫人开出了长长的购物单,都是有打折 ...

  6. 2017第八届蓝桥杯C/C++ B组省赛-等差素数列

    标题:等差素数列 2,3,5,7,11,13,....是素数序列. 类似:7,37,67,97,127,157 这样完全由素数组成的等差数列,叫等差素数数列. 上边的数列公差为30,长度为6. 200 ...

  7. 第八届蓝桥杯C/C++ B组省赛----分巧克力

    分巧克力 问题描述 儿童节那天有K位小朋友到小明家做客.小明拿出了珍藏的巧克力招待小朋友们. 小明一共有N块巧克力,其中第i块是Hi x Wi的方格组成的长方形. 为了公平起见,小明需要从这 N 块巧 ...

  8. 2016 第七届蓝桥杯 c/c++ B组省赛真题及解题报告

    2016 第七届蓝桥杯 c/c++ B组省赛真题及解题报告 勘误1:第6题第4个 if最后一个条件粗心写错了,答案应为1580. 条件应为abs(a[3]-a[7])!=1,宝宝心理苦啊.!感谢zzh ...

  9. 2015年第六届蓝桥杯C/C++B组省赛题目解析

    一.奖券数目 有些人很迷信数字,比如带“4”的数字,认为和“死”谐音,就觉得不吉利.虽然这些说法纯属无稽之谈,但有时还要迎合大众的需求.某抽奖活动的奖券号码是5位数(10000-99999),要求其中 ...

随机推荐

  1. 在Android Studio2.3中配置OpenCV4Android SDK

    在Android Studio2.3中配置OpenCV4Android SDK 一,OpenCV4Android下载地址 [2.4.11]http://onhdz331f.bkt.clouddn.co ...

  2. codeforces 722E Research Rover

    codeforces 722E Research Rover 题意 \(1e5*1e5\)的棋盘中有\(2000\)个坏点,初始给定一个值\(s(1<=s<=1e6)\).从棋盘左上角走到 ...

  3. 初探BeEF

    1.什么是BeEF? 就是 The Browser Exploitation Framework 的缩写,意在通过一些手段,控制对方的浏览器. 里面集成了很多模块,能够获取很多东西,有cookie,浏 ...

  4. 关于Linq中First、FirstOrDefault;Single、SingleOrDefault等方法的说明

    关于Linq中First.FirstOrDefault:Single.SingleOrDefault等方法的说明 这里以First.FirstOrDefault进行说明,其他类似. 1.First:取 ...

  5. 几个第三方yum源

    1.repoforge 官方网站:http://repoforge.org/ 2.epel http://fedoraproject.org/wiki/EPEL 3.Remi http://rpms. ...

  6. ios 性能优化概述

    在开发IOS程序的时候,不止是简简单单的把代码堆砌起来,或者说有一个比较好的架构,程序就ok的.还需要在程序性能上进行优化.所谓优化,并非只是简单的优化几个算法,让程序看起来跑的更快.优化是有目标的, ...

  7. Win8.1下运行环境/配置问题解决方案总结

    目录 1.运行 adb shell 时报错" adb server version (26) doesn't match this client (39); killing... " ...

  8. CADisplayLink分析

    1.固定频率定时器: 2.UI帧率性能检测: 3.cpu动画控制器:

  9. SVM中为何间隔边界的值为正负1

    在WB二面中,问到让讲一下SVM算法. 我回答的时候,直接答道线性分隔面将样本分为正负两类,取平行于线性切割面的两个面作为间隔边界,分别为:wx+b=1和wx+ b = -1. 面试官就问,为什么是正 ...

  10. 基于HP DL388 Gen 9服务器基本配置(ESXI 6.5)

    最近一段时间由于做毕业设计的原因,一直处于忙碌状态,刚做完毕业设计,导师处于项目的原因,买了一台惠普服务器(人民币1.7万),服务器自带的内存仅有16 G,硬盘也就只有600G,而且磁盘还做了raid ...