“陌上人如玉,公子世无双!”|

xxj112

园龄:2年10个月粉丝:11关注:18

8-1900E - Transitive Graph

题意:

思路:tarjan缩点后,对新图DAG进行拓扑dp。
代码:

点击查看代码
#include<bits/stdc++.h>
#define int long long 
using namespace std;
const int N=1e6+7;
const int inf=1e9+7;
typedef pair<int,int> pll;
int n,m;
int dfn[N], low[N];
int vis[N];
vector<int> ve[N];
int deep=0;
stack<int> s;
int  color[N];
int sum=0;
void tarjan(int u) {
    dfn[u]=++deep;
    low[u]=deep;
    vis[u]=1;
    s.push(u);
    for(int i=0;i<ve[u].size();i++)
    {
        int v=ve[u][i];
        if(!dfn[v])
        {
            tarjan(v);
            low[u]=min(low[u],low[v]);
        }
        else
        {
            if(vis[v])
            {
                low[u]=min(low[u],low[v]);
            }
        }
    }
    if(dfn[u]==low[u])
    {
        color[u]=++sum;
        // cout<<u<<" "<<sum<<"s\n";
        vis[u]=0;
        while(s.size()&&s.top()!=u)
        {
            color[s.top()]=sum;
            vis[s.top()]=0;
            s.pop();
        }
        s.pop();
    }

}
pll w[N];
int a[N];
vector<int> v2[N];
vector<int> v3[N];
int rd[N];
void init()
{
    for(int i=1;i<=n;i++)
    {
        w[i]={0,0};
        v2[i].clear();
        ve[i].clear();
        v3[i].clear();
        vis[i]=0;
        dfn[i]=low[i]=0;
    }
    deep=0;
    sum=0;
    while(s.size())
    {
        s.pop();
    }
}
void solve()
{
    cin>>n>>m;
    init();
    int x,y,z;
    for(int i=1;i<=n;i++) cin>>a[i];
    for(int i=1;i<=m;i++)
    {
        cin>>x>>y;
        ve[x].push_back(y);
    }
    for(int i=1;i<=n;i++)
    {
        if(!dfn[i]) tarjan(i);
        //cout<<dfn[i]<<" ";
    }   
    for(int i=1;i<=n;i++)
    {
        w[color[i]].first++;
        w[color[i]].second+=a[i];
      //  cout<<color[i]<<" ";
        for(auto v:ve[i])
        {
            if(color[v]!=color[i])
            {
                v2[color[i]].push_back(color[v]);
                v3[color[v]].push_back(color[i]);
                rd[color[v]]++;
            }
        }
    }
    int a1=0,a2=0;
    queue<int> q; 
    for(int i=1;i<=sum;i++)
    {
        if(rd[i]==0)
        {   
            q.push(i);

        }
      //  cout<<w[i].first<<" "<<w[i].second<<" w\n";
    }
    while(q.size())
    {
        int w1=q.front();
        q.pop();
        // cout<<w1<<endl;
        for(auto v:v2[w1])
        {
            rd[v]--;

            if(rd[v]==0)
            {
                q.push(v);
                int b1=0,b2=0;
             
                for(int i=0;i<v3[v].size();i++)
                {
                    int ss=v3[v][i];
                    if(w[ss].first>b1)
                    {
                        b1=w[ss].first;
                        b2=w[ss].second;
                    }
                    else if(w[ss].first==b1)
                    {
                        b2=min(w[ss].second,b2);
                    }
                }

                w[v].first+=b1;
                w[v].second+=b2;
            }
            
        }
    }
    for(int i=1;i<=sum;i++)
    {
        if(w[i].first>a1)
        {
            a1=w[i].first;
            a2=w[i].second;
        }
        else if(w[i].first==a1)
        {
            a2=min(w[i].second,a2);
        }
    }
    
        cout<<a1<<" "<<a2<<"\n";
}
signed  main()
{
    ios::sync_with_stdio(0);
    cin.tie(0);

   
    int t=1;
    cin>>t;
    while(t--)
    {
        solve();
    }
    return 0;
}

本文作者:xxj112

本文链接:https://www.cnblogs.com/xxj112/p/17865767.html

版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。

posted @   xxj112  阅读(15)  评论(0编辑  收藏  举报
评论
收藏
关注
推荐
深色
回顶
收起
  1. 1 椿 沈以诚
椿 - 沈以诚
00:00 / 00:00
An audio error has occurred.

作词 : 沈以诚

作曲 : 沈以诚

恍惚间 浸透了回忆

漫漫的回忆 存在的回忆

只看见 遗忘的笑脸

纯洁的笑脸不在身边

想实现 从前的诺言

不轻的诺言 和你的诺言

却描绘 无期限的诗

由寓意的诗刻画的线

乔木落叶 告诉我时间变迁

你仍旧倚靠石头看岁岁年年

惊觉两鬓霜白长叹一声哀怨

也不过匆匆弹指间

不在意我存在你心里面

只记得当时没有那么远

一眼朝如青丝暮成雪

美梦惊你不在眼前

我想给你一颗我的眼

倒映着曾拾起的缘

若皆是一场镜花水月

也不想忘记你的颜

唯一心愿

恍惚间 浸透了回忆

恍惚间 浸透了回忆

漫漫的回忆 存在的回忆

只看见 遗忘的笑脸

纯洁的笑脸不在身边

想实现 从前的诺言

不轻的诺言 和你的诺言

却描绘 无期限的诗

由寓意的诗刻画的线

乔木落叶 告诉我时间变迁

你仍旧倚靠石头看岁岁年年

惊觉两鬓霜白长叹一声哀怨

也不过匆匆弹指间

不在意我存在你心里面

只记得当时没有那么远

一眼朝如青丝暮成雪

美梦惊你不在眼前

我想给你一颗我的眼

倒映着曾拾起的缘

若皆是一场镜花水月

也不想忘记你的颜

唯一心愿

点击右上角即可分享
微信分享提示