码迷,mamicode.com
首页 > 其他好文 > 详细

ALGORITHM1.5 Union-find implementation(p221)

时间:2018-05-24 16:36:14      阅读:141      评论:0      收藏:0      [点我收藏+]

标签:ati   turn   OLE   txt   关于   import   nec   class   div   

//我在drjava里无法运行,所以没办法只能到终端里运行

//没有tinyUF.txt的请看我关于algs4环境配置的那片文章(里面有整本书测试数据的下载)

import edu.princeton.cs.algs4.*;

public class UF
{
    private int[] id;
    private int count;
    
    public UF(int N)
    {
        count = N;
        id = new int[N];
        for(int i = 0; i < N; i++)
        {
            id[i] = i;
        }
    }
    
    public int count()
    {
        return count;
    }
    
    public boolean connected(int p, int q)
    {
        return find(p) == find(q);
    }
    //我用了p222的quick-find
    public int find(int p)
    {
        return id[p];
    }
    
    public void union(int p, int q)
    {
        int pID = find(p);
        int qID = find(q);
        if(pID == qID)
            return;
        for(int i = 0; i < id.length; i++)
        {
            if(id[i] == pID)
                id[i] = qID;
        }
        count--;
    }
    
    public static void main(String[] args)
    {
        int N = StdIn.readInt();
        UF uf = new UF(N);
        while(!StdIn.isEmpty())
        {
            int p = StdIn.readInt();
            int q = StdIn.readInt();
            if(uf.connected(p,q))
                continue;
            uf.union(p,q);
            StdOut.println(p + " " + q);
        }
        StdOut.println(uf.count() + " components");
    }
}

 

ALGORITHM1.5 Union-find implementation(p221)

标签:ati   turn   OLE   txt   关于   import   nec   class   div   

原文地址:https://www.cnblogs.com/w-j-c/p/9083095.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!