热门标签 | HotTags
当前位置:  开发笔记 > 程序员 > 正文

[POI2008]BLO-Blockade(tarjan割点)

题目链接:https:www.luogu.orgproblemnewshowP3469题意:在n个点m条边的无向图,求删掉一个点后,有多少个有序(x,y)由连通到不连通思

题目链接:https://www.luogu.org/problemnew/show/P3469

 

题意:在n个点m条边的无向图,求删掉一个点后,有多少个有序(x,y)由连通到不连通

 

思路:

分两种情况:

1.点不为割点,答案就是(n-1)*2(这个点到其他的点,其他的点到这个点)

2.点是割点,那么图被分成一些部分,答案就是每个部分点的个数与其他部分的个数乘积的和,再加上(n-1)*2(即上面的)

举个例子:

 

比如删掉割点3时

每个部分与其他点的乘积的和:12,也可以这样计算:

集合(1)    *   集合(2)  =1

集合(1,2)  *   集合(4)=2

集合(1,2,4)*   集合(5)=3  这里只算了一边,所以答案就是 6*2

怎么实现?在搜索中加上去就行,看代码:

#include
#include
#include
#include
using namespace std;
typedef long long ll;
const int maxn=1e5+10;
struct node{
    int next,to;
}edge[maxn*10];
ll head[maxn],low[maxn],dfn[maxn];
ll ans[maxn],size[maxn];//ans为答案,size[i]存储以i为根子树的大小 
int n,m,cnt,tot;
void add(int u,int v)
{
    edge[cnt].to=v;
    edge[cnt].next=head[u];
    head[u]=cnt++;
}

void tarjan(int u)
{
    low[u]=dfn[u]=++tot;
    ll z=0;//记录已求出割点后集合的大小,相当于上面列子左边的集合 
    size[u]=1;//初始 
    for(int i=head[u];i!=-1;i=edge[i].next)
    {
        int v=edge[i].to;
        if(!dfn[v])
        {
            tarjan(v);
            size[u]+=size[v];//没遍历过当然要加上子树的大小,来求出以u为根子树的大小 
            low[u]=min(low[u],low[v]);
            if(low[v]>=dfn[u])//v为割点 
            {
                ans[u]+=(ll)z*size[v];//模拟上面例子乘的过程 
                z+=size[v];//记得集合变大 
            }
        }
        else
            low[u]=min(low[u],dfn[v]);
    }
    ans[u]+=(ll)z*(n-1-z);//不要忘了,这是最后一步(不只要具体用处,个人理解是算不是割点时的答案) 
}

int main()
{
    cnt=tot=0;
    memset(head,-1,sizeof(head));
    memset(low,0,sizeof(low));
    memset(dfn,0,sizeof(dfn));
    memset(ans,0,sizeof(ans));
    memset(size,0,sizeof(size));
    int x,y;
    scanf("%d%d",&n,&m);
    for(int i=1;i<=m;i++)
    {
        scanf("%d%d",&x,&y);
        add(x,y);
        add(y,x);
    }
    tarjan(1);
    for(int i=1;i<=n;i++)
        printf("%lld\n",(ans[i]+n-1)<<1);
    return 0;
}
View Code

 


推荐阅读
  • QBlog开源博客系统:Page_Load生命周期与参数传递优化(第四部分)
    本教程将深入探讨QBlog开源博客系统的Page_Load生命周期,并介绍一种简洁的参数传递重构方法。通过视频演示和详细讲解,帮助开发者更好地理解和应用这些技术。 ... [详细]
  • SQL中UPDATE SET FROM语句的使用方法及应用场景
    本文详细介绍了SQL中UPDATE SET FROM语句的使用方法,通过具体示例展示了如何利用该语句高效地更新多表关联数据。适合数据库管理员和开发人员参考。 ... [详细]
  • python的交互模式怎么输出名文汉字[python常见问题]
    在命令行模式下敲命令python,就看到类似如下的一堆文本输出,然后就进入到Python交互模式,它的提示符是>>>,此时我们可以使用print() ... [详细]
  • 火星商店问题:线段树分治与持久化Trie树的应用
    本题涉及编号为1至n的火星商店,每个商店有一个永久商品价值v。操作包括每天在指定商店增加一个新商品,以及查询某段时间内某些商店中所有商品(含永久商品)与给定密码值的最大异或结果。通过线段树分治和持久化Trie树来高效解决此问题。 ... [详细]
  • Java 中的 BigDecimal pow()方法,示例 ... [详细]
  • 本文总结了汇编语言中第五至第八章的关键知识点,涵盖间接寻址、指令格式、安全编程空间、逻辑运算指令及数据重复定义等内容。通过详细解析这些内容,帮助读者更好地理解和应用汇编语言的高级特性。 ... [详细]
  • 探讨如何高效使用FastJSON进行JSON数据解析,特别是从复杂嵌套结构中提取特定字段值的方法。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 本文详细介绍了如何使用Maven高效管理多模块项目,涵盖项目结构设计、依赖管理和构建优化等方面。通过具体的实例和配置说明,帮助开发者更好地理解和应用Maven在复杂项目中的优势。 ... [详细]
  • 本文介绍了如何在具备多个IP地址的FTP服务器环境中,通过动态地址端口复用和地址转换技术优化网络配置。重点讨论了2Mb/s DDN专线连接、Cisco 2611路由器及内部网络地址规划。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 本文介绍了在安装或运行 Python 项目时遇到的 'ModuleNotFoundError: No module named setuptools_rust' 错误,并提供了解决方案。 ... [详细]
  • CentOS7源码编译安装MySQL5.6
    2019独角兽企业重金招聘Python工程师标准一、先在cmake官网下个最新的cmake源码包cmake官网:https:www.cmake.org如此时最新 ... [详细]
  • 构建基于BERT的中文NL2SQL模型:一个简明的基准
    本文探讨了将自然语言转换为SQL语句(NL2SQL)的任务,这是人工智能领域中一项非常实用的研究方向。文章介绍了笔者在公司举办的首届中文NL2SQL挑战赛中的实践,该比赛提供了金融和通用领域的表格数据,并标注了对应的自然语言与SQL语句对,旨在训练准确的NL2SQL模型。 ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
author-avatar
Jay_5
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有