现在的位置: 首页 > 综合 > 正文

hdu1535

2013年10月13日 ⁄ 综合 ⁄ 共 1546字 ⁄ 字号 评论关闭

/*
分析:
    我靠,ac了,泪奔~~~
    为了做这个题,学会了静态邻接表~~~,今儿有接近一半的
时间都花到这个题上了,今儿做的题少了点儿,不过,值~~!

    用Dij+优先队列过的,578MS。
    菜菜有一点儿不懂呀,第一次用的SPFA,竟然连5秒都超了,
感觉着SPFA会慢点儿,但不应该慢这么多呀0.0

    欢迎讨论,欢迎指点~~~O(∩_∩)O~

                                                     2012-07-27
*/

#include"stdio.h"
#include"string.h"
#include"queue"
using namespace std;


int n;
struct A
{
	int dis;
	int flag;
}E[1000111];
struct node
{
	int num;
	int dis;
	friend bool operator<(node n1,node n2)
	{
		return n2.dis<n1.dis;
	}
};


struct Eage
{
	int from;
	int to;
	int len;
	int next;
}eage[2][1000111];
int tot[2];
int head[2][1000111];
void add(int a,int b,int c,int k)
{
	eage[k][tot[k]].from=a;
	eage[k][tot[k]].to=b;
	eage[k][tot[k]].len=c;
	eage[k][tot[k]].next=head[k][a];
	head[k][a]=tot[k]++;
}


priority_queue<node>q;
void Dij(int z)
{
	node cur,next;
	int temp;
	int flag;


	cur.num=1;
	cur.dis=0;
	q.push(cur);
	while(!q.empty())
	{
		cur=q.top();
		q.pop();
		if(!E[cur.num].flag)	continue;
		E[cur.num].flag=0;


		temp=head[z][cur.num];
		flag=0;
		do
		{
			if(flag)	temp=eage[z][temp].next;
			flag=1;
			if(E[cur.num].dis+eage[z][temp].len<E[eage[z][temp].to].dis)
			{
				E[eage[z][temp].to].dis=E[cur.num].dis+eage[z][temp].len;
				next.num=eage[z][temp].to;
				next.dis=E[eage[z][temp].to].dis;
				q.push(next);
			}
		}
		while(eage[z][temp].next!=-1);
	}
}


int main()
{
	int T;
	int q;
	int i;
	int a,b,c;
	int ans;


	scanf("%d",&T);
	while(T--)
	{
		scanf("%d%d",&n,&q);
		tot[0]=tot[1]=0;
		memset(head,-1,sizeof(head));
		while(q--)
		{
			scanf("%d%d%d",&a,&b,&c);
			add(a,b,c,0);
			add(b,a,c,1);
		}


		ans=0;


		for(i=1;i<=n;i++)	{E[i].dis=1111111111;E[i].flag=1;}
		E[1].dis=0;
		Dij(0);
		for(i=1;i<=n;i++)	ans+=E[i].dis;


		for(i=1;i<=n;i++)	{E[i].dis=1111111111;E[i].flag=1;}
		E[1].dis=0;
		Dij(1);
		for(i=1;i<=n;i++)	ans+=E[i].dis;


		printf("%d\n",ans);
	}
	return 0;
}

抱歉!评论已关闭.