uva11324 The Largest Clique --- 强连通+dp

简介:

给一个有向图G,求一个子图要求当中随意两点至少有一边可达。

问这个子图中最多含多少个顶点。


首先找SCC缩点建图。每一个点的权值就是该点包括点的个数。

要求当中随意两点可达,实际上全部边仅仅能同方向,不然一定有两点不可达,

这样题目又转换成求DAG图最长路的问题了。

然后从入度为0的点開始记忆化搜索。dp[i]表示以i为根最多包括多少点。


#include <iostream>
#include <cstring>
#include <string>
#include <cstdio>
#include <cmath>
#include <algorithm>
#include <vector>
#include <queue>
#include <map>
#define inf 0x3f3f3f3f
#define eps 1e-6
#define ll __int64
#define M 1010
using namespace std;

int sta[M],top;          //Tarjan 算法中的栈
bool vis[M];             //检查是否在栈中
int dfn[M];                  //深度优先搜索訪问次序
int low[M];                  //能追溯到的最早的次序
int ccnt;                //有向图强连通分量个数
int id;                 //索引號
vector<int> e[M];        //邻接表表示
vector<int> part[M];   //获得强连通分量结果
int inpart[M];   //记录每一个点在第几号强连通分量里
int degree[M];     //记录每一个强连通分量的度
vector<int> edge[M];//缩点后建图
int ans,n,m,dp[M],in[M],point[M];

void tarjan(int x)
{
    int i,j;
    dfn[x]=low[x]=id++;
    vis[x]=1;
    sta[++top]=x;
    for(i=0;i<e[x].size();i++)
    {
        j=e[x][i];
        if(dfn[j]==-1)
        {
            tarjan(j);
            low[x]=min(low[x],low[j]);
        }
        else if(vis[j])
            low[x]=min(low[x],dfn[j]);
    }
    if(dfn[x]==low[x])
    {
        do
        {
            j=sta[top--];
            vis[j]=0;
            part[ccnt].push_back(j);
            inpart[j]=ccnt;
            point[ccnt]++;
        }while(j!=x);
        ccnt++;
    }
}

void solve(int n)
{
    memset(sta,-1,sizeof sta);
    memset(vis,0,sizeof vis);
    memset(dfn,-1,sizeof dfn);
    memset(low,-1,sizeof low);
    memset(point,0,sizeof point);

    top=ccnt=id=0;
    for(int i=1;i<=n;i++)
        if(dfn[i]==-1)
            tarjan(i);
}

int dfs(int x)
{
    if(dp[x]) return dp[x];
    dp[x]=point[x];
    int i;
    for(i=0;i<edge[x].size();i++)
    {
        int tmp=edge[x][i];
        dp[x]=max(dp[x],point[x]+dfs(tmp));
    }
    return dp[x];
}

int main()
{
    int n,m,i,j,a,b,t;
    scanf("%d",&t);
    while(t--)
    {
        scanf("%d%d",&n,&m);
        for(i=0;i<=n;i++)
        {
            part[i].clear();
            e[i].clear();
            edge[i].clear();
        }
        while(m--)
        {
            scanf("%d%d",&a,&b);
            e[a].push_back(b);
        }
        solve(n);
        /*printf("ccnt:%d\n",ccnt);
        for(i=0;i<ccnt;i++)
        {
            for(j=0;j<part[i].size();j++)
                printf("%d ",part[i][j]);
            puts("");
        }*/
        memset(in,0,sizeof in);
        for(i=1;i<=n;i++)//枚举原图中的边
        {
            for(j=0;j<e[i].size();j++)
            {
                int a=inpart[i];
                int b=inpart[e[i][j]];//
                if(a!=b)
                {
                    in[b]++;
                    edge[a].push_back(b);
                }
            }
        }
        ans=0;
        memset(dp,0,sizeof dp);
        for(i=0;i<ccnt;i++)//缩点后的图上是从0到ccnt编号的
        {
            if(!in[i])
                ans=max(ans,dfs(i));
        }
        printf("%d\n",ans);
    }
    return 0;
}




本文转自mfrbuaa博客园博客,原文链接:http://www.cnblogs.com/mfrbuaa/p/5364945.html,如需转载请自行联系原作者 
相关文章
|
资源调度 Java 调度
Spring Cloud Alibaba 集成分布式定时任务调度功能
定时任务在企业应用中至关重要,常用于异步数据处理、自动化运维等场景。在单体应用中,利用Java的`java.util.Timer`或Spring的`@Scheduled`即可轻松实现。然而,进入微服务架构后,任务可能因多节点并发执行而重复。Spring Cloud Alibaba为此发布了Scheduling模块,提供轻量级、高可用的分布式定时任务解决方案,支持防重复执行、分片运行等功能,并可通过`spring-cloud-starter-alibaba-schedulerx`快速集成。用户可选择基于阿里云SchedulerX托管服务或采用本地开源方案(如ShedLock)
320 1
|
6月前
|
存储 安全 API
如何下载旧版本的 Postman?
旧版本的 Postman 可能有助于更好地兼容不同的框架。 了解如何找到 Postman 的确切版本,以便优化你的 API 开发!
如何下载旧版本的 Postman?
|
算法 JavaScript 前端开发
JavaScript学习 -- SM4算法应用实例
JavaScript学习 -- SM4算法应用实例
697 0
|
小程序
【微信小程序-原生开发】列表 - 拖拽排序(官方组件 movable-area 和 movable-view 的用法)
【微信小程序-原生开发】列表 - 拖拽排序(官方组件 movable-area 和 movable-view 的用法)
1328 0
|
缓存 Java
为什么线程池不允许使用Executors去创建?
Executors Executors存在什么问题 Executors为什么会OOM 创建线程池的正确姿势
为什么线程池不允许使用Executors去创建?
|
6天前
|
弹性计算 人工智能 安全
云上十五年——「弹性计算十五周年」系列客户故事(第二期)
阿里云弹性计算十五年深耕,以第九代ECS g9i实例引领算力革新。携手海尔三翼鸟、小鹏汽车、微帧科技等企业,实现性能跃升与成本优化,赋能AI、物联网、智能驾驶等前沿场景,共绘云端增长新图景。
|
12天前
|
存储 弹性计算 人工智能
【2025云栖精华内容】 打造持续领先,全球覆盖的澎湃算力底座——通用计算产品发布与行业实践专场回顾
2025年9月24日,阿里云弹性计算团队多位产品、技术专家及服务器团队技术专家共同在【2025云栖大会】现场带来了《通用计算产品发布与行业实践》的专场论坛,本论坛聚焦弹性计算多款通用算力产品发布。同时,ECS云服务器安全能力、资源售卖模式、计算AI助手等用户体验关键环节也宣布升级,让用云更简单、更智能。海尔三翼鸟云服务负责人刘建锋先生作为特邀嘉宾,莅临现场分享了关于阿里云ECS g9i推动AIoT平台的场景落地实践。
【2025云栖精华内容】 打造持续领先,全球覆盖的澎湃算力底座——通用计算产品发布与行业实践专场回顾
|
4天前
|
云安全 人工智能 安全
Dify平台集成阿里云AI安全护栏,构建AI Runtime安全防线
阿里云 AI 安全护栏加入Dify平台,打造可信赖的 AI