题目:http://acm.hdu.edu.cn/showproblem.php?pid=5934

  1. 根据距离关系建边
  2. 对于强连通分量来说,只需引爆话费最小的炸弹即可引爆整个强连通分量
  3. 将所有的强连通分量缩成点,我们就得到了一棵树,我们只需要引爆树根的炸弹即可
  4. 我们可以处理出每个点所属的强连通分量的拓扑序,或者说染色法,把属于同一个强连通分量的点标上同一个数字
  5. 处理完强连通分量后,我们不需要建树,我们可以用并查集来维护,更好的办法是统计每个点的入度,入读为0即为根节点
     #include<bits/stdc++.h>
    using namespace std;
    typedef long long ll;
    const int maxv = ;
    int V;//总共点的个数
    vector<int> g[maxv];
    vector<int> rg[maxv];
    vector<int> vs;
    bool used[maxv];
    int cmp[maxv];//保存拓扑序
    ll cost[maxv];//每个拓扑序的话费
    ll x[],y[],r[],c[];
    ////scc
    void dfs(int v){
    used[v] = true;
    for(int i = ;i<g[v].size();i++)
    if(!used[g[v][i]])
    dfs(g[v][i]);
    vs.push_back(v);
    }
    void rdfs(int v,int k){
    used[v] = true;
    cmp[v] = k;
    cost[k] = min(cost[k],c[v]);//处理出每个强连通分量的最小话费
    for(int i = ;i<rg[v].size();i++)
    if(!used[rg[v][i]])
    rdfs(rg[v][i],k);
    }
    int scc(){
    memset(used,,sizeof(used));
    vs.clear();
    for(int v = ;v<=V;v++)//这里要注意,下标是从0开始还是从1开始
    if(!used[v])
    dfs(v);
    memset(used,,sizeof(used));
    int k = ;
    for(int i = vs.size()-;i>=;i--)
    if(!used[vs[i]])
    rdfs(vs[i],k++);
    return k;
    }
    //////
    void addedge(int i,int j){
    ll dis = (y[i]-y[j])*(y[i]-y[j])+(x[i]-x[j])*(x[i]-x[j]);
    if(dis <= r[i]*r[i]){
    g[i].push_back(j);
    rg[j].push_back(i);
    }
    if(dis <= r[j]*r[j]){
    g[j].push_back(i);
    rg[i].push_back(j);
    }
    }
    //////
    int du[];
    int main(){
    int t;
    cin >> t;
    int cas = ;
    while(t--){
    int n;
    cin >> n;
    V = n;
    memset(cost,0x3f3f3f3f,sizeof(cost));
    for(int i = ;i<=n;i++){
    g[i].clear();
    rg[i].clear();
    }
    for(int i = ;i<=n;i++){
    scanf("%I64d%I64d%I64d%I64d",&x[i],&y[i],&r[i],&c[i]);
    for(int j = ;j<i;j++){
    addedge(i,j);
    }
    }
    int k = scc();
    memset(du,,sizeof(du));
    for(int i = ;i<=n;i++)
    for(int j = ;j<g[i].size();j++)
    if(cmp[i] != cmp[g[i][j]])//拓扑序不同,度数加1
    du[cmp[g[i][j]]]++;
    ll ans = ;
    for(int i = ;i<k;i++)
    if(du[i] == )
    ans += cost[i] ;
    printf("Case #%d: %I64d\n",cas++,ans);
    }
    return ;
    }

HDU5934 强连通分量的更多相关文章

  1. 【HDU5934】Bomb——有向图强连通分量+重建图

    题目大意 二维平面上有 n 个爆炸桶,i−thi-thi−th爆炸桶位置为 (xi,yi)(x_i, y_i)(xi​,yi​) 爆炸范围为 rir_iri​ ,且需要 cic_ici​ 的价格引爆, ...

  2. POJ1236Network of Schools[强连通分量|缩点]

    Network of Schools Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 16571   Accepted: 65 ...

  3. 有向图的强连通分量的求解算法Tarjan

    Tarjan算法 Tarjan算法是基于dfs算法,每一个强连通分量为搜索树中的一颗子树.搜索时,把当前搜索树中的未处理的结点加入一个栈中,回溯时可以判断栈顶到栈中的结点是不是在同一个强连通分量中.当 ...

  4. Tarjan算法--强连通分量

    tarjan的过程就是dfs过程. 图一般能画成树,树的边有三种类型,树枝边 + 横叉边(两点没有父子关系) + 后向边(两点之间有父子关系): 可以看到只有后向边能构成环,即只有第三张图是强连通分量 ...

  5. 强连通分量的一二三 | | JZOJ【P1232】 | | 我也不知道我写的什么

    贴题: 在幻想乡,上白泽慧音是以知识渊博闻名的老师.春雪异变导致人间之里的很多道路都被大雪堵塞,使有的学生不能顺利地到达慧音所在的村庄.因此慧音决定换一个能够聚集最多人数的村庄作为新的教学地点.人间之 ...

  6. 有向图强连通分量的Tarjan算法

    有向图强连通分量的Tarjan算法 [有向图强连通分量] 在有向图G中,如果两个顶点间至少存在一条路径,称两个顶点强连通(strongly connected).如果有向图G的每两个顶点都强连通,称G ...

  7. poj2186Popular Cows(Kosaraju算法--有向图的强连通分量的分解)

    /* 题目大意:有N个cows, M个关系 a->b 表示 a认为b popular:如果还有b->c, 那么就会有a->c 问最终有多少个cows被其他所有cows认为是popul ...

  8. Tarjan应用:求割点/桥/缩点/强连通分量/双连通分量/LCA(最近公共祖先)【转】【修改】

    一.基本概念: 1.割点:若删掉某点后,原连通图分裂为多个子图,则称该点为割点. 2.割点集合:在一个无向连通图中,如果有一个顶点集合,删除这个顶点集合,以及这个集合中所有顶点相关联的边以后,原图变成 ...

  9. POJ 1236 Network of Schools(强连通分量/Tarjan缩点)

    传送门 Description A number of schools are connected to a computer network. Agreements have been develo ...

随机推荐

  1. app开发项目简单的结构一

    一 .Network (网络) 1. 接口类(可以一个放所有接口的头文件)ApiConfig.h. (1). 可以放服务器的地址.图片服务器的地址及其它接口的地址(这样做的好处是只用导入一个头文件即可 ...

  2. PDF/WORD/EXCEL/PPT 文档在线阅读

    查资料看了2种解决方法: 1.通过办公软件dll转换,用flans去看 2.通过Aspose转换成pdf格式,在用js前台读pdf(我用的pdf.js) 今天我解决的就是WORD/EXCEL/PPT ...

  3. 对比Haproxy和Nginx负载均衡效果

    为了对比Hproxy和Nginx负载均衡的效果,分别在测试机上(以下实验都是在单机上测试的,即负载机器和后端机器都在一台机器上)做了这两个负载均衡环境,并各自抓包分析.下面说下这两种负载均衡环境下抓包 ...

  4. 解决ASP.NET上传文件大小限制

    第一种方法,主要适用于IIS6.0版本 一.修改配置Web.Config文件中的httpRuntime节点对于asp.net,默认只允许上传4M文件,增加如下配置,一般可以自定义最大文件大小.一.修改 ...

  5. .NET WebAPI 用ActionFilterAttribute实现token令牌验证与对Action的权限控制

    项目背景是一个社区类的APP(求轻吐...),博主主要负责后台业务及接口.以前没玩过webAPI,但是领导要求必须用这个(具体原因鬼知道),只好硬着头皮上了. 最近刚做完权限这一块,分享出来给大家.欢 ...

  6. python学习之路 第六天

    1.正则表达式 re.match() 从头匹配: re.match("[0-9]","123abc789") 只匹配一个数字: re.match("[ ...

  7. 1.ios synthesize有什么作用

    ###1.ios synthesize有什么作用 当定义了一系列的变量时,需要写很多的getter和setter方法,而且它们的形式都是差不多的,所以Xcode提供了@property和@synthe ...

  8. sql server 多列转多行实现方法

    select * from b_workOrder select * from( SELECT work_order_id,work_level, roles,code FROM (SELECT wo ...

  9. ngrok反向隧道--获取内网IP

    ngrok反向隧道 前情提要:小明与小白各有一台主机,两台主机在同一内网,小明想直接通过内网ssh到小白的主机上.但是小白的ip地址会不断的变化,而小明不想每次都要麻烦小白查看ip.于是小明催生了一个 ...

  10. [转] C++的引用传递、指针传递参数在java中的相应处理方法

    原文出处:[http://blog.csdn.net/conowen/article/details/7420533] 首先要明白一点,java是没有指针这个概念的. 但是要实现C++的引用传递.指针 ...