• P1262 间谍网络


    先缩点,如果缩完点的所有入度为零的点都可以被收买

    那么总代价就是收买他们的代价之和

    反之不能全部收买

    在实现的时候

    for(int i=1; i<=n; i++)
            if(!dfn[i]&&money[i]!=2139062143)
                tarjan(i);
    

    是为了防止一个不愿意被收买的人成为根(也许吧)

    CODE

    #include<algorithm>
    #include<iostream>
    #include<cstring>
    #include<cstdio>
    #include<stack>
    using namespace std;
    
    int money[10010];
    int from[10010],to[10010],nex[10010],head[10010];
    int dfn[10010],low[10010],scc[10010],scce[10010],sccm[10010],dfsn,sccn;
    int instack[10010],ans;
    stack <int> s;
    
    void tarjan(int u)
    {
        dfn[u]=low[u]=++dfsn;
        instack[u]=true;
        s.push(u);
        for(int i=head[u]; i; i=nex[i])
        {
            if(!dfn[to[i]])
            {
                tarjan(to[i]);
                low[u]=min(low[u],low[to[i]]);
            }
            else if(instack[to[i]])
                low[u]=min(low[u],dfn[to[i]]);
        }
        if(dfn[u]==low[u])
        {
            int v;
            ++sccn;
            do
            {
                v=s.top();
                s.pop();
                scc[v]=sccn;
                sccm[sccn]=min(sccm[sccn],money[v]);
                instack[v]=false;
            }
            while(u!=v);
        }
        return ;
    }
    
    int main()
    {
        ios::sync_with_stdio(false);
        memset(sccm,0x7f,sizeof(sccm));
        memset(money,0x7f,sizeof(money));
        int n,p,x,y;
        cin>>n>>p;
        for(int i=1; i<=p; i++)
        {
            cin>>x>>y;
            money[x]=y;
        }
        cin>>p;
        for(int i=1; i<=p; i++)
        {
            cin>>x>>y;
            from[i]=x;
            to[i]=y;
            nex[i]=head[x];
            head[x]=i;
        }
        for(int i=1; i<=n; i++)
            if(!dfn[i]&&money[i]!=2139062143)
                tarjan(i);
        for(int i=1; i<=n; i++)
            if(!dfn[i])
            {
                cout<<"NO"<<endl;
                cout<<i;
                return 0;
            }
        for(int i=1; i<=n; i++)
            for(int j=head[i]; j; j=nex[j])
                if(scc[i]!=scc[to[j]])
                    scce[scc[to[j]]]++;
        for(int i=1; i<=sccn; i++)
            if(scce[i]==0)
                ans+=sccm[i];
        cout<<"YES"<<endl;
        cout<<ans;
        return 0;
    }
    
  • 相关阅读:
    课堂讨论电子版
    项目目标文档
    系统利益相关者
    实训八(游戏背景)
    实训七(项目准备与创建)
    实训六(Cocos2dx游戏分享到微信朋友圈----AppID的获取)
    实训五(Cocos2dx-3.x 打包apk再理解)
    实训四(cocos2dx sharesdk集成-1)
    实训三(cocos2dx 3.x 打包apk)
    实训二(cocos2dx 2.x 打包apk)
  • 原文地址:https://www.cnblogs.com/Alarak26/p/9374384.html
Copyright © 2020-2023  润新知