jQuery火箭图标返回顶部代码 - 站长素材
jQuery火箭图标返回顶部代码 - 站长素材

洛谷P2194 【HXY烧情侣】

首先请允许我吐槽一下这个题面

这个题面透露出血腥与暴力,电影院里还藏汽油

所以情侣们,要是想看电影就在家里看吧

毕竟出来容易被烧

在家里看虽然观影效果不如在电影院里

但是,

起码咱生命安全啥的有保障啊

题面

思路:

tarjan

注意方案数是乘法原理

#include <cstdio>
#include <iostream>
using namespace std;
const int N = 1e6+7;
const int md = 1e9+7;
int n, head[N << 1], cnt,  w[N], m, dfn[N], low[N], tot, top, stac[N], ans, minn, sum = 1, geshu;
bool vis[N];
struct node {
    int nxt, to;
}e[N << 1];
int read() {
    int s = 0, w = 1;
    char ch = getchar();
    while(!isdigit(ch)) {if(ch == '-') w = -1; ch = getchar();}
    while(isdigit(ch)) {s = s * 10 + ch - '0'; ch = getchar();}
    return s * w;
}
void add(int x, int y) {
    e[++cnt].nxt = head[x];
    e[cnt].to = y;
    head[x] = cnt;
}
void tarjan(int u) {
    dfn[u] = low[u] = ++tot, stac[++top] = u, vis[u] = 1;
    for(int i = head[u]; i; i = e[i].nxt) {
        int v = e[i].to;
        if(!dfn[v]) tarjan(v), low[u] = min(low[u], low[v]);
        else if(vis[v]) low[u] = min(low[u], dfn[v]); 
    }
    if(dfn[u] == low[u]) {
        geshu = 0,     minn = 0x3f3f3f3f;
        while(stac[top] != u) {
            vis[stac[top]] = 0;
            if(w[stac[top]] < minn) minn = w[stac[top]], geshu = 0;
            if(w[stac[top--]] == minn) geshu++;
        }
        top--, vis[u] = 0;
        if(w[u] < minn) minn = w[u], geshu = 1;
        else if(w[u] == minn) geshu++;
        ans += minn;
        sum = (sum * geshu) % md;
    }
} 
int main() {
    n = read();
    for(int i = 1; i <= n; i++) w[i] = read();
    m = read();
    for(int i = 1, x, y; i <= m; i++) {
        x = read(), y = read();
        add(x, y);
    }
    for(int i = 1; i <= n; i++) 
        if(!dfn[i]) tarjan(i);
    printf("%d %d\n", ans, sum);
    return 0;
}

谢谢收看, 祝身体健康!

 

posted @ 2019-10-28 15:33  lzpclxf  阅读(152)  评论(0编辑  收藏  举报