最短路+次短路(Dijkstra+priority_queue)

题意是要求你找出最短路的条数+与最短路仅仅差1的次短路的条数。

開始仅仅会算最短路的条数,和次短路的长度。真是给次短路条数跪了。ORZ。其它人都用Dijkstra。我想试试SPFA。

然后大神说要把这个最短,次短都拿去push。并且要用最短来。priority_queue。优先队列。妈蛋,这不是优先队列优化的Dijkstra么。

改得无比忧伤。反正開始改来改去连例子都过不了。

后来想着 假设最短能够更新,原来的最短就变成次短了。

思路来了,刷刷就写完了。

WA……ORZ。

。。

最后对照大神的才知道。我push的仅仅有节点和长度。须要把标记也进去。

OOOOOOOOORZ。

#include<cstdio>
#include<cstring>
#include<string>
#include<queue>
#include<algorithm>
#include<map>
#include<stack>
#include<iostream>
#include<list>
#include<set>
#include<cmath>
#define INF 0x7fffffff
#define eps 1e-6
#define LL long long
using namespace std;
int n,m;
struct lx
{
int v,len;
};
vector <lx> g[1001]; struct node
{
bool flag;
int u;
LL len;
node(LL llen,int uu,bool fflag):len(llen),u(uu),flag(fflag){} };
bool operator <(node a,node b)
{
return a.len>b.len;
}
void Dijkstra(int start,int thend)
{
bool vis[1001][2];
int cot[1001][2];
LL dis[1001][2];
for(int i=1; i<=n; i++)
{
for(int j=0;j<2;j++)
dis[i][j]=INF,cot[i][j]=0,vis[i][j]=0;;
}
priority_queue<node>q;
q.push(node(0,start,0));
dis[start][0]=0;
cot[start][0]=cot[start][1]=1; while(!q.empty())
{
node now=q.top();q.pop();
int u=now.u;
// printf("%lld %d %d==\n",now.len,now.u,now.flag);
if(vis[u][now.flag])continue;
vis[u][now.flag]=1; for(int j=0;j<g[u].size();j++)
{
LL tmp=g[u][j].len+now.len;
int v=g[u][j].v; if(dis[v][0]>tmp)
{
dis[v][1]=dis[v][0];
cot[v][1]=cot[v][0];
dis[v][0]=tmp;
cot[v][0]=cot[u][now.flag];
q.push(node(tmp,v,0));
q.push(node(dis[v][1],v,1)); }
else if(dis[v][0]==tmp)
cot[v][0]+=cot[u][now.flag];
else if(dis[v][1]>tmp)
{
dis[v][1]=tmp;
cot[v][1]=cot[u][now.flag];
q.push(node(tmp,v,1));
}
else if(dis[v][1]==tmp)
cot[v][1]+=cot[u][now.flag];
}
}
// for(int i=1;i<=n;i++)
// printf("%d :%lld-%lld\n",i,dis[i][0],dis[i][1]); if(dis[thend][0]+1!=dis[thend][1])
printf("%d\n",cot[thend][0]);
else
printf("%d\n",cot[thend][0]+cot[thend][1]);
} int main()
{
int t;
scanf("%d",&t);
while(t--)
{
scanf("%d%d",&n,&m);
for(int i=1; i<=n; i++)
g[i].clear();
int u,v,len;
lx now;
while(m--)
{
scanf("%d%d%d",&u,&v,&len);
now.v=v,now.len=len;
g[u].push_back(now);
}
int start,thend;
scanf("%d%d",&start,&thend);
Dijkstra(start,thend);
}
}

POJ 3463 Sightseeing的更多相关文章

  1. poj 3463 Sightseeing( 最短路与次短路)

    http://poj.org/problem?id=3463 Sightseeing Time Limit: 2000MS   Memory Limit: 65536K Total Submissio ...

  2. POJ - 3463 Sightseeing 最短路计数+次短路计数

    F - Sightseeing 传送门: POJ - 3463 分析 一句话题意:给你一个有向图,可能有重边,让你求从s到t最短路的条数,如果次短路的长度比最短路的长度多1,那么在加上次短路的条数. ...

  3. poj 3463 Sightseeing——次短路计数

    题目:http://poj.org/problem?id=3463 当然要给一个点记最短路和次短路的长度和方案. 但往优先队列里放的结构体和vis竟然也要区分0/1,就像把一个点拆成两个点了一样. 不 ...

  4. POJ 3463 Sightseeing (次短路经数)

    Sightseeing Time Limit: 2000MS   Memory Limit: 65536K Total Submissions:10005   Accepted: 3523 Descr ...

  5. POJ 3463 Sightseeing 【最短路与次短路】

    题目 Tour operator Your Personal Holiday organises guided bus trips across the Benelux. Every day the ...

  6. POJ 3463 Sightseeing 题解

    题目 Tour operator Your Personal Holiday organises guided bus trips across the Benelux. Every day the ...

  7. poj 3463 Sightseeing(次短路+条数统计)

    /* 对dij的再一次理解 每个点依旧永久标记 只不过这里多搞一维 0 1 表示最短路还是次短路 然后更新次数相当于原来的两倍 更新的时候搞一下就好了 */ #include<iostream& ...

  8. POJ 3463 Sightseeing (次短路)

    题意:求两点之间最短路的数目加上比最短路长度大1的路径数目 分析:可以转化为求最短路和次短路的问题,如果次短路比最短路大1,那么结果就是最短路数目加上次短路数目,否则就不加. 求解次短路的过程也是基于 ...

  9. POJ 1637 Sightseeing tour(最大流)

    POJ 1637 Sightseeing tour 题目链接 题意:给一些有向边一些无向边,问能否把无向边定向之后确定一个欧拉回路 思路:这题的模型很的巧妙,转一个http://blog.csdn.n ...

随机推荐

  1. JavaScript设计模式与开发实践——读书笔记1.高阶函数(下)

    上部分主要介绍高阶函数的常见形式,本部分将着重介绍高阶函数的高级应用. 1.currying currying指的是函数柯里化,又称部分求值.一个currying的函数会先接受一些参数,但不立即求值, ...

  2. java验证openssl生成的ssl证书和私钥是否匹配

    最近有一个需求上传ssl证书和私钥,但是上传之前需要验证ssl证书和私钥是否正确,其中的业务逻辑涉及到以下几点: 一.读取ssl证书,读取ssl证书公钥       要实现该功能比较简单,java里面 ...

  3. April Fools Day Contest 2016 B. Scrambled

    B. Scrambled 题目连接: http://www.codeforces.com/contest/656/problem/B Description Btoh yuo adn yuor roo ...

  4. 2015编程之美 初赛第一场C题 质数相关 二分图的最大匹配

    质数相关 Time Limit: 1 Sec  Memory Limit: 256 MB 题目连接 http://hihocoder.com/contest/msbop2015round2a/prob ...

  5. StringFormat

    public class StringFormatDemo { public static void main(String[] args) { String str = null; str = St ...

  6. Redmine 邮件配置

    高版本号的Redmine是没有email.yml的.是和configuration.yml合并了.仅仅要配置configuration.yml即可了. 首先得说下Redmine的邮件,配置这个邮件,是 ...

  7. 让linux history命令显示命令的运行时间、在哪个机器运行的这个命令

    1.在/etc/profile的最后加入例如以下部分: USER_IP=`who -u am i 2>/dev/null| awk '{print $NF}'|sed -e 's/[()]//g ...

  8. Matlab Command Window 进度提示

    效果如下,

  9. eclipse安装Run-Jetty-Run插件,修改实时生效

    http://marketplace.eclipse.org/content/run-jetty-run   1.直接拖拽到eclipse安装(7/8/9版本都安装) 2.以调试的方式启动jetty( ...

  10. 怎样解决MySQL数据库主从复制延迟的问题

    像Facebook.开心001.人人网.优酷.豆瓣.淘宝等高流量.高并发的网站,单点数据库很难支撑得住,WEB2.0类型的网站中使用MySQL的居多,要么用MySQL自带的MySQL NDB Clus ...