比赛 20160412 评测结果 AAAAAAAAAAAAATEAEEEA
题目名称 正则表达式 最终得分 75
用户昵称 mikumikumi 运行时间 3.380 s
代码语言 C++ 内存使用 6.80 MiB
提交时间 2016-04-12 11:15:52
显示代码纯文本
#include<cstdio>
#include<vector>
#include<deque>
#include<iostream>
#include<queue>
using namespace std;
const int SIZEN=200010,INF=0x7fffffff/2;
int N,M;
vector<pair<int,int> > s[SIZEN];
deque<int> Q;
void read()
{
	scanf("%d%d",&N,&M);
	int u,v,w;
	for(int i=1;i<=M;i++) 
	{
		scanf("%d%d%d",&u,&v,&w);
		s[u].push_back(make_pair(v,w));
	}
}
int dfn[SIZEN],low[SIZEN],co[SIZEN];
int tim=0,id[SIZEN],cnt=0;
void dfs(int x)
{
	//cout<<x<<endl;
	low[x]=dfn[x]=++tim;
	co[x]=1;
	Q.push_back(x);
	for(int i=0;i<s[x].size();i++)
	{
		int v=s[x][i].first;
		if(co[v]==1)
		{
			low[x]=min(low[x],dfn[v]);
		}
		if(!co[v])
		{
			dfs(v);
			low[x]=min(low[x],low[v]);
		}
	}
	co[x]=2;
	if(low[x]>=dfn[x])
	{
		cnt++;
		while(true)
		{
			int v=Q.back();Q.pop_back();
			id[v]=cnt;
			if(v==x) break;
		}
	}
}
bool vis[SIZEN]={0};
void dfs2(int x)
{
	vis[x]=1;
	for(int i=0;i<s[x].size();i++)
	{
		int v=s[x][i].first;
		if(vis[v]) continue;
		if(id[v]==id[x])
		{
			s[x][i].second=0;
			dfs2(v);
		}
	}
}
priority_queue<pair<int,int> > P;
int f[SIZEN];
bool inq[SIZEN]={0};
void dijstra()
{
	for(int i=2;i<=N;i++) f[i]=INF;
	P.push(make_pair(0,1));
	while(!P.empty())
	{
		int x=P.top().second;inq[x]=0;P.pop();
		for(int i=0;i<s[x].size();i++)
		{
			int v=s[x][i].first,w=s[x][i].second;
			if(f[x]+w<f[v])
			{
				f[v]=f[x]+w;
				if(!inq[v])
				{
					inq[v]=1;
					P.push(make_pair(-f[v],v));
				}
			}
		}
	}
}
void work()
{
	for(int i=1;i<=N;i++)
	{
		if(!co[i]) dfs(i);
	}
	for(int i=1;i<=N;i++)
	{
		if(!vis[i])
		dfs2(i);
	}
	dijstra();
	printf("%d\n",f[N]);
	//for(int i=1;i<=N;i++) cout<<id[i]<<endl;
}
int main()
{
	freopen("regexp.in","r",stdin);
	freopen("regexp.out","w",stdout);
	read();
	work();
	return 0;
}