`
200830740306
  • 浏览: 109421 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

Poj1308 并查集

J# 
阅读更多
package middle;


import java.io.BufferedInputStream;
import java.util.Scanner;

/**
 * poj1308
 * 判断是否是一棵只有一个根,并且到每个结点的路径唯一的树
 * 多种解法,这里用并查集
 * 1.空树也是一棵树
 * 2.不是同一棵树就合并,输入的边的两个顶点同根,说明有环
 * 3.注意,森林不是一棵树
 * @author NC
 */
public class Poj1308 {

    public static void main(String[] args) {
        final int MAXSIZE = 10000;
        int[] edge1 = new int[MAXSIZE];
        int[] edge2 = new int[MAXSIZE];
        Scanner scan = new Scanner(new BufferedInputStream(System.in));
        String r1 = "is a tree.";
        String r2 = "is not a tree.";
        int caseI = 1;//记录case
        int root = 0;//查是否是森林用的
        while (scan.hasNext()) {
            int a = scan.nextInt();
            int b = scan.nextInt();
            if (a == -1 && b == -1) {
                break;
            }
            int j = 0;
            //先读取每一个case的所有边再处理,方便判断空树
            for (j = 0;; j++) {
                if (a == 0 && b == 0) {
                    break;
                }
                edge1[j] = a;
                edge2[j] = b;
                a = scan.nextInt();
                b = scan.nextInt();
            }
            if (j == 0) {
                //空树
                System.out.println("Case " + caseI + " " + r1);
                caseI++;
            } else {
                String result = "";
                boolean resultFlag = true;
                DisjointSet dj = new DisjointSet(MAXSIZE);
                for (int jj = 0; jj < j; jj++) {
                    if (dj.parent[edge1[jj]] == 0) {
                        dj.init(edge1[jj]);
                    }
                    if (dj.parent[edge2[jj]] == 0) {
                        dj.init(edge2[jj]);
                    }
                    root = edge1[jj];
                    int ra = dj.find(edge1[jj]);
                    int rb = dj.find(edge2[jj]);
                    if (ra == rb) {
                        //有环,不是一棵按要求的树
                        resultFlag = false;
                        break;//一发现环就可以直接输出结果,输入的,前面已经处理了
                    } else {
                        dj.union(ra, rb);
                    }
                }
                result = "Case " + caseI + " ";
                if (resultFlag) {
                    int k;
                    for (k = 0; k < MAXSIZE; k++) {
                        if (dj.parent[k] != 0) {
                            if (dj.find(k) != dj.find(root)) {
                                result += r2;
                                break;
                            }
                        }
                    }
                    if (k == MAXSIZE) {
                        result += r1;
                    }
                } else {
                    result += r2;
                }
                System.out.println(result);
                caseI++;
            }

        }
    }
}

class DisjointSet {

    protected int n;
    protected int[] parent;
    protected int[] rank;

    public DisjointSet(int n) {
        this.n = n;
        init();
    }

    private void init() {
        this.parent = new int[this.n + 1];
        this.rank = new int[this.n + 1];
    }

    protected void init(int i) {
        parent[i] = i;
        rank[i] = 1;
    }

    protected int find(int x) {//返回第x号元素的根结点
        if (parent[x] != x) {
            parent[x] = find(parent[x]);
        }
        return parent[x];
    }

    protected void union(int ra, int rb) {
        if (rank[ra] > rank[rb]) {
            parent[rb] = ra;
        } else if (rank[ra] < rank[rb]) {
            parent[ra] = rb;
        } else {
            rank[rb]++;
            parent[ra] = rb;
        }
    }
}

分享到:
评论

相关推荐

    poj2492并查集应用的扩展

    poj2492 A Bug's Life并查集应用的扩展,希望可以给大家带来用处

    POJ 1988 简单并查集,

    根据给定的信息,本文将详细解释“POJ 1988 简单并查集”中的核心知识点,包括并查集的基本概念、代码实现以及在本题中的具体应用。 ### 并查集基本概念 并查集是一种用于处理一些不交集的合并及查询问题的数据...

    数据结构--并查集(Union-Find Sets)

    此外,它也是算法竞赛中的常见题目类型,例如POJ等在线编程平台上的题目就经常涉及并查集的使用。 综上所述,并查集是一种非常实用的数据结构,它在处理集合的连接与查找问题时具有高效性和灵活性,对于理解和掌握...

    并查集(Union Find set)基础

    并查集基础 acm 算法 poj oi 并查集基础.ppt

    并查集问题

    1. poj2524.cpp:这是一个POJ(Problem Setter's Online Judge)的编程题目,通常涉及到特定的算法问题,可能需要利用并查集解决连通性或路径查找问题。 2. hdoj1233最小生成树,克鲁斯卡尔.cpp:最小生成树是图论...

    1089_bingchaji.rar_1089_bingchaji.rar _并查集

    在给定的标题“1089_bingchaji.rar_1089_bingchaji.rar _并查集”和描述“POJ1089 并查集可以解决 并查集加路径压缩”中,我们可以看到这是一个关于使用并查集解决特定问题的案例,可能来自于编程竞赛或练习。...

    并查集C++实现

    这份代码用C++实现了经典算法并查集,来源于poj题目1182

    poj 1611 The Suspects 代码

    poj 1611 The Suspects 代码 并查集的应用

    POJ1011-Sticks

    一种常见的方法是使用深度优先搜索(DFS)或广度优先搜索(BFS)来构建线段之间的连接,并通过并查集(Disjoint Set)数据结构来判断是否存在不相交的集合。 1. **数据结构**:首先,我们需要用数组或者链表存储...

    并查集总结

    以POJ 1988为例,这是一个经典的并查集应用题,题目要求计算每个木箱上面还有多少木箱。通过并查集的查找和合并操作,结合路径压缩,可以有效地解决这一问题。 ```cpp #include #include void unionu(int x, int...

    POJ算法题目分类

    * 简单并查集:简单并查集是指解决问题的简单并查集算法。 * 哈希表和二分查找等高效查找法:哈希表和二分查找等高效查找法是指解决问题的高效查找算法,如 poj3349、poj3274、POJ2151、poj1840、poj2002、poj2503。...

    poj题目分类

    * 并查集的高级应用:例如 poj1703、poj2492。 * KMP 算法:例如 poj1961、poj2406。 4. 搜索: * 最优化剪枝和可行性剪枝。 * 搜索的技巧和优化:例如 poj3411、poj1724。 * 记忆化搜索:例如 poj3373、poj...

    POJ 1679 练习克鲁斯卡尔kruskal 算法

    在Java环境下,你可以使用ArrayList来存储边以及它们的权重,用HashSet或者TreeSet对边进行排序,同时利用并查集(Disjoint Set)进行环路检测。 【文件名称列表】: Main.java 这表明你需要在Main.java文件中编写...

    详解并查集(0基础可飞速掌握其基本原理).pdf

    ### 并查集详解 #### 一、并查集简介 并查集是一种非常重要的数据结构,主要用于处理一些不相交集合的合并及查询问题。它具有高效且简洁的特点,在算法竞赛以及实际应用中有着广泛的应用场景。比如在网络连接、...

    poj训练计划.doc

    - 并查集的高级应用:如`poj1703, poj2492`。 - **搜索** - 最优化剪枝和可行性剪枝:如`poj3411, poj1724`。 - **动态规划** - 复杂的动态规划:如`poj1191, poj1054`。 - 记录状态的动态规划:如`poj3254, ...

    poj各种分类

    Prim算法和Kruskal算法分别基于贪心策略和并查集数据结构,用于在带权图中找到连接所有顶点的最小总权重的树结构。 #### 拓扑排序 适用于有向无环图,帮助分析任务依赖关系,如poj1094所示。 #### 匹配算法 包括...

    POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类

    - **解释**:并查集是一种用于处理集合合并及查询操作的数据结构。 #### 2. 特殊优化技巧 - **例题**:poj3393, poj1472, poj3371, poj1027, poj2706 - **解释**:特殊优化技巧通常涉及特定问题的优化算法,如位...

    ACM-POJ 算法训练指南

    3. **并查集**:用于处理不相交集合的问题(poj1195, poj3321)。 4. **区间查询**:如RMQ问题(poj3264, poj3368)。 5. **字符串匹配**:如KMP算法(poj1961, poj2406)。 ### 十三、进阶算法 1. **组合优化**:...

    POJ 1861 Network

    【标题】"POJ 1861 Network"是一个经典的计算机科学问题,它涉及到图论中的网络连接,并要求我们利用并查集(Disjoint Set)数据结构来检测图中的环路,同时应用快速排序算法来求解最小生成树。这个问题在ACM(国际...

Global site tag (gtag.js) - Google Analytics