坑题,题目描述不清楚。


1:“ 接下来n行每行两个数字表示相互连通的点”,题目说相互连通容易误解为两个顶点可以相互畅通,其实只是a点到b点,b不能到a。

2: 题目没有说明接下来输入的n行数字的范围,通过样例输入很容易误解为范围<=n。


这题,不做也罢!


import java.util.Scanner;

public class Main {

	/**
	 * @param args
	 */
	public static int arr[][],flag[][],n;//存储输入数据
	public static boolean result;
	public static void main(String[] args) {
		Scanner sc=new Scanner(System.in);
		while (sc.hasNext()) {
			n=sc.nextInt();
			
			flag=new int[n+10][n+10];//标记是否走过
			arr=new int[n+10][n+10];
			//输入
			for (int i = 0; i <n; i++) {
				int start=sc.nextInt();
				int end=sc.nextInt();
				arr[start][end]=1;//标记有路
			}
			int p=sc.nextInt();//初始位置
			result=true;
			dfs(p);
			if (result) {
				System.out.println("Yes");
			}else {
				System.out.println("No");
			}
		}
}
	//搜索
	public static void dfs(int detp) {
		for (int i = 1; i <=n; i++) {
			if (arr[detp][i]==1 && flag[detp][i]==1) {//原地打转
				result=false;
				return ;
			}
			if (arr[detp][i]==1 && flag[detp][i]==0) {//有路线,且没走过
				flag[detp][i]=1;
				dfs(i);
				flag[detp][i]=0;
			}
		}
	}
	
	
}


点赞(0)
 

0.0分

4 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 3 条评论

王玉辰 4年前 回复TA
卧槽 磊哥还是顶啊
陈正磊 4年前 回复TA
@龚秋志 这题目描述的不清楚,坑的很。
龚秋志 4年前 回复TA
厉害啊,我之前一直没看懂题目是什么意思