poj 2762 Going from u to v or from v to u? (推断它是否是一个薄弱环节图)

poj 2762 Going from u to v or from v to u? (推断它是否是一个薄弱环节图)

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

意甲冠军:给定一个有向图有m单向边缘。免费推断是否两点起来(a可以b要么b可以a或最多彼此),该请求

            弱联通重量。

算法:

缩点求强连通分量。然后又一次建图。推断新图是否是一条单链,即不能分叉,假设分叉了就会存在不可达的情况。

怎么推断是否是单链呢?

就是每次入度为0的点都仅仅有一个,即每次队列里仅仅有一个点。

poj 2762 Going from u to v or from v to u? (推断它是否是一个薄弱环节图)(    o(╯□╰)o。。。。

。好像已经是第二次用pair记录原图的点对,然后存pair的vector忘记清空导致wa来wa去!

#include<cstdio>
#include<iostream>
#include<cstring>
#include<queue>
#include<vector>
#define maxn 1010
#define maxm 20010

using namespace std;

struct node
{
    int to,next;
}edge[maxm],edge2[maxm];
int head[maxn],cnt,n;
int clk,top,s[maxn],scc,dfn[maxn],low[maxn],belong[maxn];
bool instack[maxn],vis[maxn];
int head2[maxn],cnt2,in[maxn];

typedef pair<int,int> PII;
vector<PII> xx;
queue<int> q;

void add(int x,int y)
{
    edge[cnt].to = y;
    edge[cnt].next = head[x];
    head[x] = cnt++;
}

void add2(int x,int y)
{
    edge2[cnt2].to = y;
    edge2[cnt2].next = head2[x];
    head2[x] = cnt2++;
}

void dfs(int x)
{
    dfn[x] = low[x] = clk++;
    s[top++] = x;
    instack[x] = true;
    for(int i=head[x];i!=-1;i = edge[i].next)
    {
        int u = edge[i].to;
        if(dfn[u]==-1)
        {
            dfs(u);
            low[x] = min(low[u],low[x]);
        }
        else if(instack[u])
        {
            low[x] = min(low[x],dfn[u]);
        }
    }
    if(low[x]==dfn[x])
    {
        int u;
        scc++;
        do
        {
            u = s[--top];
            instack[u]=false;
            belong[u] = scc;
        }while(u!=x);
    }
}

void tarjan()
{
    memset(dfn,-1,sizeof(dfn));
    memset(instack,0,sizeof(instack));
    memset(belong,0,sizeof(belong));
    clk = top = scc = 0;
    for(int i=1;i<=n;i++)
    {
        if(dfn[i]==-1)
            dfs(i);
    }
}

bool topo()
{
    memset(vis,0,sizeof(vis));
    int c = 0;
    while(!q.empty())
        q.pop();
    for(int i=1;i<=scc;i++)
    {
        if(!in[i])
        {
            c++;
            q.push(i);
        }
    }
    if(c>1) return false;
    while(!q.empty())
    {
        int u = q.front();
        q.pop();
        if(vis[u]) continue;
        vis[u] = true;
        c = 0;
        for(int i=head2[u];i!=-1;i=edge2[i].next)
        {
            int v = edge2[i].to;
            in[v]--;
            if(!in[v])
            {
                q.push(v);
                c++;
            }
        }
        if(c>1)
            return false;
    }
    return true;
}

int main()
{
    int m,a,b,T;
    scanf("%d",&T);
    while(T--)
    {
        scanf("%d%d",&n,&m);
        memset(head,-1,sizeof(head));
        memset(in,0,sizeof(in));
        xx.clear();
        cnt = 0;
        for(int i=1;i<=m;i++)
        {
            scanf("%d%d",&a,&b);
            add(a,b);
            xx.push_back(make_pair(a,b));
        }
        tarjan();
        memset(head2,-1,sizeof(head2));
        cnt2 = 0;
        for(int i=0;i<xx.size();i++)
        {
            int u = xx[i].first,v = xx[i].second;
            if(belong[u]!=belong[v])
            {
                add2(belong[u],belong[v]);
                in[belong[v]]++;
            }
        }
        if(topo()) printf("Yes\n");
        else printf("No\n");
    }
    return 0;
}

版权声明:本文博客原创文章,博客,未经同意,不得转载。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/117526.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • VB.NET窗体继承「建议收藏」

    VB.NET窗体继承「建议收藏」VB.NET窗体继承

    2022年4月24日
    41
  • 子网划分和计算方法(附习题详解)

    子网划分和计算方法(附习题详解)一.子网划分作用1.计算网络号,通过网络号选择正确的网络设备连接终端设备1)清楚IP地址四点段点分十进制数和子网掩码,对应的网络号是什么2)交换机是用来连接相同网络的设备,路由器是用来连接不同网段的设备网络号一样的,即在相同网段,网络号不一样的,即不同网段3)计算方法把十进制数的IP地址换算成二进制数,把子网掩码也由十进制数换算成二进制数,两对二进制数对齐做“与”运算,即可得出网络号。2.根据网络的规模,可以对局域网(内网)进行网络地址规划二.IP地址格…

    2022年6月27日
    34
  • PB 生成和解析JSON格式数据「建议收藏」

    PB 生成和解析JSON格式数据「建议收藏」一创建用户对象sailjsonforwardglobaltypesailjsonfromnonvisualobjectendtypetypejson_pairfromstructurewithinsailjsonendtypeendforwardtypejson_pairfromstructurestringnameanyvalueendtypeglobal

    2025年8月4日
    9
  • css中placeholder用法_html placeholder

    css中placeholder用法_html placeholder#iInput::-webkit-input-placeholder{color:blue;}#iInput:-moz-placeholder{color:blue;}#iInput:-ms-

    2022年8月1日
    8
  • 网站 XSS 防范措施 脚本

    网站 XSS 防范措施 脚本

    2021年5月9日
    131
  • 说一下java的运行机制_Java运行机制是什么?「建议收藏」

    说一下java的运行机制_Java运行机制是什么?「建议收藏」不管是学习Java还是其他什么变成语言,我们不仅要了解它的特性,充分的使用Java语言完成各种程序开发工作,还要了解Java的运行机制。只有了解其底层的运行机制,才能更好的利用Java完成各项工作。Java运行机制是什么?Java程序运行时,必须经过编译和运行两个步骤。首先将后缀名师“.java”的源文件进行编译,最终生成后缀名为“.class”的字节码文件。然后Java虚拟机将编译后的字节码文件…

    2022年7月7日
    24

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号