AC日记——[SDOI2010]大陆争霸 洛谷 P3690

[SDOI2010]大陆争霸

思路:

   dijkstra模板;

代码:

#include <bits/stdc++.h>
using namespace std;
#define maxn 3005
#define ll long long
#define maxm 70002<<2
#define INF 1e13
struct NodeType {
ll id,dis;
bool operator<(const NodeType pos)const
{
return dis>pos.dis;
}
};
ll n,m,E1[maxm],V1[maxm],W[maxm],head1[maxn];
ll cnt1,cnt2,E2[maxm],V2[maxm],head2[maxn],dis1[maxn];
ll dis2[maxn],du[maxn];
bool vis[maxn];
priority_queue<NodeType>que;
inline void in(ll &now)
{
char Cget=getchar();now=;
while(Cget>''||Cget<'') Cget=getchar();
while(Cget>=''&&Cget<='')
{
now=now*+Cget-'';
Cget=getchar();
}
}
void edge_add(ll u,ll v,ll w)
{
E1[++cnt1]=head1[u],V1[cnt1]=v,W[cnt1]=w,head1[u]=cnt1;
}
void edge_add(ll u,ll v)
{
E2[++cnt2]=head2[u],V2[cnt2]=v,head2[u]=cnt2;
}
NodeType node(ll id_,ll dis_)
{
NodeType res;
res.id=id_,res.dis=dis_;
return res;
}
int main()
{
in(n),in(m);ll u,v,w;
while(m--) in(u),in(v),in(w),edge_add(u,v,w);
for(ll i=;i<=n;i++)
{
in(u),dis1[i]=INF;
while(u--) in(v),edge_add(v,i),du[i]++;
}
dis1[]=dis2[]=,que.push(node(,));
while(!que.empty())
{
NodeType now=que.top();que.pop();
if(vis[now.id]) continue;
vis[now.id]=true;
for(ll i=head1[now.id];i;i=E1[i])
{
if(dis1[V1[i]]>max(dis1[now.id],dis2[now.id])+W[i])
{
dis1[V1[i]]=max(dis1[now.id],dis2[now.id])+W[i];
if(!du[V1[i]]) que.push(node(V1[i],max(dis1[V1[i]],dis2[V1[i]])));
}
}
for(ll i=head2[now.id];i;i=E2[i])
{
dis2[V2[i]]=max(dis2[V2[i]],max(dis1[now.id],dis2[now.id]));
if(!(--du[V2[i]])) que.push(node(V2[i],max(dis1[V2[i]],dis2[V2[i]])));
}
}
cout<<max(dis1[n],dis2[n]);
return ;
}
上一篇:Android之zip文件加密解压及进度条的实现


下一篇:《C++编程思想》第四章 初始化与清除(原书代码+习题+解答)