热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

hdu1272小希的迷宫解题报告

题目链接:http:acm.hdu.edu.cnshowproblem.php?pid1272第二条并查集,和畅通工程的解法类似。判断小希的迷宫不符合条

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1272

      第二条并查集,和畅通工程的解法类似。判断小希的迷宫不符合条件,即有回路。我的做法是,在合并两个集合的时候,当fx = fy,即有共同祖先的时候,说明就有回路。

     这题有三点要注意:1、格式问题。题目说的“每两组数据之间有一个空行。”是会PE的!!实际上输出Yes或No之后加多个\n即可,不需要再画蛇添足再输多一个换行。  2、 当整数对列表只有0 0 时,要输出Yes   3、当不相交的集合个数>=2时,也是不符合条件的,要输出No

     

1 #include
2 #include
3 #include <string.h>
4 using namespace std;
5
6 const int maxn &#61; 100000 &#43; 5;
7 int set[maxn], flag[maxn];
8 int sign;
9
10 int find_set(int x)
11 {
12 while (x !&#61; set[x])
13 x &#61; set[x];
14 return x;
15 }
16
17 void union_set(int x, int y)
18 {
19 int fx &#61; find_set(x);
20 // printf("fx &#61; %d\n", fx);
21 int fy &#61; find_set(y);
22 // printf("fy &#61; %d\n", fy);
23 if (fx !&#61; fy)
24 {
25 set[fx] &#61; fy;
26 // printf("set[%d] &#61; %d\n", fx, set[fx]);
27 }
28 else
29 sign &#61; 1;
30 }
31
32 int main()
33 {
34 int a, b, i, j, cnt;
35 memset(set, 0, sizeof(set));
36 memset(flag, 0, sizeof(flag));
37 i &#61; sign &#61; 0;
38 while (scanf("%d%d", &a, &b) && (a !&#61; -1 || b !&#61; -1))
39 {
40 if (i &#61;&#61; 0 && a &#61;&#61; 0 && b &#61;&#61; 0) // i &#61; 0代表列表中的数据是第一组
41 {
42 printf("Yes\n");
43 }
44 else if (a !&#61; 0 && b !&#61; 0)
45 {
46 i&#43;&#43;;
47 if (!flag[a] && set[a] !&#61; a) // flag的作用是输入数据时当存在多个相同的数据时&#xff0c;保证只需要存入一次set[a]&#xff0c;起到类似监视哨的作用
48 {
49 set[a] &#61; a;
50 flag[a] &#61; 1;
51 // printf("set[%d] &#61; %d\n", a, set[a]);
52 }
53 if (!flag[b] && set[b] !&#61; b)
54 {
55 set[b] &#61; b;
56 flag[b] &#61; 1;
57 // printf("set[%d] &#61; %d\n", b, set[b]);
58 }
59 if (a > b)
60 swap(a, b); // 保证小的数指向的祖先比它大,其实这个判断不要也行
61
union_set(a, b); // 合并a、b元素&#xff0c;使a、b成为一个集合
62 }
63 else
64 {
65 for (cnt &#61; 0, j &#61; 1; j )
66 if (set[j] &#61;&#61; j) // 统计不相交集合个数
67 cnt&#43;&#43;;
68 if (cnt > 1) // 不相交集合个数超过1个
69 sign &#61; 1;
70 if (sign)
71 printf("No\n");
72 else
73 printf("Yes\n");
74 memset(set, 0, sizeof(set));
75 memset(flag, 0, sizeof(flag));
76 i &#61; sign &#61; 0;
77 }
78 }
79 return 0;
80 }

 

    

    

    

    

转:https://www.cnblogs.com/windysai/p/3254941.html



推荐阅读
  • 寒假作业解析:第三周 2月12日 第7题
    尽快完成之前的练习任务!每日一练2.1 Problem A Laurenty and Shop 的题目要求是选择两条不同的路线以最小化总的等待时间。简要分析:通过对比不同路线的等待时间,可以找到最优解。此问题可以通过动态规划或贪心算法来解决,具体取决于路线的复杂性和约束条件。 ... [详细]
  • 本文深入探讨了佩尔方程 \( x^2 - dy^2 = 1 \) 的递推关系式。通过构造特定的矩阵并利用矩阵快速幂的方法,可以高效地计算出该方程的第 k 组解。此外,文章还详细分析了递推关系式的数学背景及其在数论中的应用,为相关研究提供了坚实的理论基础。 ... [详细]
  • 单链表的高效遍历及性能优化策略
    本文探讨了单链表的高效遍历方法及其性能优化策略。在单链表的数据结构中,插入操作的时间复杂度为O(n),而遍历操作的时间复杂度为O(n^2)。通过在 `LinkList.h` 和 `main.cpp` 文件中对单链表进行封装,我们实现了创建和销毁功能的优化,提高了单链表的使用效率。此外,文章还介绍了几种常见的优化技术,如缓存节点指针和批量处理,以进一步提升遍历性能。 ... [详细]
  • 图论入门基础教程
    图论是计算机科学和数学中的重要分支,本教程旨在为初学者提供全面的基础知识。通过实例解析,如“昂贵的聘礼”问题,讲述了一个年轻探险家在印第安部落与酋长女儿的爱情故事,展示了图论在解决实际问题中的应用。教程内容涵盖了图的基本概念、表示方法以及常见算法,适合各类读者学习。 ... [详细]
  • 在洛谷 P1344 的坏牛奶追踪问题中,第一问要求计算最小割,而第二问则需要找到割边数量最少的最小割。通过为每条边附加一个单位权值,可以在求解最小割时优先选择边数较少的方案,从而同时解决两个问题。这种策略不仅简化了问题的求解过程,还确保了结果的最优性。 ... [详细]
  • 如何利用Java 5 Executor框架高效构建和管理线程池
    Java 5 引入了 Executor 框架,为开发人员提供了一种高效管理和构建线程池的方法。该框架通过将任务提交与任务执行分离,简化了多线程编程的复杂性。利用 Executor 框架,开发人员可以更灵活地控制线程的创建、分配和管理,从而提高服务器端应用的性能和响应能力。此外,该框架还提供了多种线程池实现,如固定线程池、缓存线程池和单线程池,以适应不同的应用场景和需求。 ... [详细]
  • 在Kohana 3框架中,实现最优的即时消息显示方法是许多开发者关注的问题。本文将探讨如何高效、优雅地展示flash消息,包括最佳实践和技术细节,以提升用户体验和代码可维护性。 ... [详细]
  • 2012年9月12日优酷土豆校园招聘笔试题目解析与备考指南
    2012年9月12日,优酷土豆校园招聘笔试题目解析与备考指南。在选择题部分,有一道题目涉及中国人的血型分布情况,具体为A型30%、B型20%、O型40%、AB型10%。若需确保在随机选取的样本中,至少有一人为B型血的概率不低于90%,则需要选取的最少人数是多少?该问题不仅考察了概率统计的基本知识,还要求考生具备一定的逻辑推理能力。 ... [详细]
  • Python全局解释器锁(GIL)机制详解
    在Python中,线程是操作系统级别的原生线程。为了确保多线程环境下的内存安全,Python虚拟机引入了全局解释器锁(Global Interpreter Lock,简称GIL)。GIL是一种互斥锁,用于保护对解释器状态的访问,防止多个线程同时执行字节码。尽管GIL有助于简化内存管理,但它也限制了多核处理器上多线程程序的并行性能。本文将深入探讨GIL的工作原理及其对Python多线程编程的影响。 ... [详细]
  • C++ 开发实战:实用技巧与经验分享
    C++ 开发实战:实用技巧与经验分享 ... [详细]
  • 具备括号和分数功能的高级四则运算计算器
    本研究基于C语言开发了一款支持括号和分数运算的高级四则运算计算器。该计算器通过模拟手算过程,对每个运算符进行优先级标记,并按优先级从高到低依次执行计算。其中,加减运算的优先级最低,为0。此外,该计算器还支持复杂的分数运算,能够处理包含括号的表达式,提高了计算的准确性和灵活性。 ... [详细]
  • 今天我开始学习Flutter,并在Android Studio 3.5.3中创建了一个新的Flutter项目。然而,在首次尝试运行时遇到了问题,Gradle任务 `assembleDebug` 执行失败,退出状态码为1。经过初步排查,发现可能是由于依赖项配置不当或Gradle版本不兼容导致的。为了解决这个问题,我计划检查项目的 `build.gradle` 文件,确保所有依赖项和插件版本都符合要求,并尝试更新Gradle版本。此外,还将验证环境变量配置是否正确,以确保开发环境的稳定性。 ... [详细]
  • iOS 设备唯一标识获取的高效解决方案与实践
    在iOS 7中,苹果公司再次禁止了对MAC地址的访问,使得开发者无法直接获取设备的物理地址。为了在开发过程中实现设备的唯一标识,苹果推荐使用Keychain服务来存储和管理唯一的标识符。此外,还可以结合其他技术手段,如UUID和广告标识符(IDFA),以确保设备的唯一性和安全性。这些方法不仅能够满足应用的需求,还能保护用户的隐私。 ... [详细]
  • 如何在页面底部添加倾斜样式效果? ... [详细]
  • 在编程笔试和面试中,全排列算法因其适中的难度而备受青睐,不仅能够考察应聘者的算法基础,还能测试其对递归和回溯的理解。本文将深入解析全排列算法的实现原理,探讨其应用场景,并提供优化建议,帮助读者更好地掌握这一重要算法。 ... [详细]
author-avatar
小乐的孤独人生_298
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有