码迷,mamicode.com
首页 > 其他好文 > 详细

BZOJ-1952缓存

时间:2016-06-15 18:57:31      阅读:103      评论:0      收藏:0      [点我收藏+]

标签:

技术分享
#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
#include<cmath>
using namespace std;
int read()
{
    int x=0,f=1; char ch=getchar();
    while (ch<0 || ch>9) {if (ch==-) f=-1; ch=getchar();}
    while (ch>=0 && ch<=9) {x=x*10+ch-0; ch=getchar();}
    return x*f;
}
struct EdgeNode{int next,to;}edge[maxn<<2];
int head[maxn],cnt;
void add(int u,int v,int w) {cnt++; edge[cnt].next=head[u]; head[u]=cnt; edge[cnt].to=v;}
void insert(int u,int v,int w) {add(u,v); add(v,u);}
int n,m;
void CactusDP(int now)
{
    
}
void TreeDP(int now,int last)
{
    dfn[now]=low[now]=++t;
    for (int i=head[now]; i; i=edge[i].next)
        if (edge[i].to!=last)
            {
                if (deep[edge[i].to]) {low[now]=min(dfn[edge[i].to],low[now]); continue;}
                fa[edge[i].to]=now;
                deep[edge[i].to]=deep[now]+1;
                DFS(edge[i].to,now);
                
                low[now]=min(low[now],low[edge[i].to]);
            }
}
int main()
{
    n=read(),m=read();
    for (int i=1; i<=n; i++) HX[i]=read();
    for (int u,v,i=1; i<=m; i++) u=read(),v=read(),insert(u,v);
    for (int i=1; i<=n; i++) if (!dfn[i]) DFS(i);
    printf("%d\n",ans);
    return 0;
}
View Code

 

BZOJ-1952缓存

标签:

原文地址:http://www.cnblogs.com/DaD3zZ-Beyonder/p/5588365.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!