个人心得:模板题,不过还是找到了很多问题,真的是头痛,为什么用dijkstra算法book【1】=1就错了.....

纠结中....

Bessie is out in the field and wants to get back to the barn to get as much sleep as possible before Farmer John wakes her for the morning milking. Bessie needs her beauty sleep, so she wants to get back as quickly as possible.

Farmer John's field has N (2 <= N <= 1000) landmarks in it, uniquely numbered 1..N. Landmark 1 is the barn; the apple tree grove in which Bessie stands all day is landmark N. Cows travel in the field using T (1 <= T <= 2000) bidirectional cow-trails of various lengths between the landmarks. Bessie is not confident of her navigation ability, so she always stays on a trail from its start to its end once she starts it.

Given the trails between the landmarks, determine the minimum distance Bessie must walk to get back to the barn. It is guaranteed that some such route exists.

Input

* Line 1: Two integers: T and N

* Lines 2..T+1: Each line describes a trail as three space-separated integers. The first two integers are the landmarks between which the trail travels. The third integer is the length of the trail, range 1..100.

Output

* Line 1: A single integer, the minimum distance that Bessie must travel to get from landmark N to landmark 1.

Sample Input

5 5
1 2 20
2 3 30
3 4 20
4 5 20
1 5 100

Sample Output

90

Hint

INPUT DETAILS:

There are five landmarks.

OUTPUT DETAILS:

Bessie can get home by following trails 4, 3, 2, and 1.

Dijkstra算法
 #include<iostream>
#include<cstdio>
#include<cmath>
#include<cstring>
#include<iomanip>
#include<algorithm>
using namespace std;
#define inf 1<<29
int t,n;
int cow[][];
int dis[];
int book[];
void dijkstra()
{
memset(book,,sizeof(book));
for(int i=;i<=n;i++) dis[i]=cow[][i];
dis[]=;
book[]=;
for(int i=;i<=n;i++)
{
int mina=inf;
int k;
for(int j=;j<=n;j++)
{
if(book[j]==&&mina>dis[j])
{
mina=dis[j];
k=j;
}
}
book[k]=;
for(int j=;j<=n;j++)
{
if(book[j]==&&dis[j]>dis[k]+cow[k][j])
dis[j]=dis[k]+cow[k][j];
}
}
}
int main()
{
while(cin>>t>>n){
int x,y,z;
for(int i=;i<=n;i++)
for(int j=;j<=n;j++)
if(i==j) cow[i][j]=;
else cow[i][j]=inf;
for(int i=;i<=t;i++){
cin>>x>>y>>z;
if(cow[x][y]>z)
cow[x][y]=cow[y][x]=z; }
dijkstra();
cout<<dis[n]<<endl;}
return ;
}

Bellman-Ford算法

 #include<iostream>
#include<cstdio>
#include<cmath>
#include<cstring>
#include<iomanip>
#include<algorithm>
using namespace std;
#define inf 1<<29
int t,n;
int u[],v[],w[];
int dis[];
int book[];
int main()
{
while(cin>>t>>n)
{
for(int i=;i<=t;i++)
cin>>u[i]>>v[i]>>w[i];
for(int i=;i<=n;i++)
dis[i]=inf;
dis[]=;
for(int i=;i<=n;i++)
for(int j=;j<=t;j++){
if(dis[v[j]]>dis[u[j]]+w[j])
dis[v[j]]=dis[u[j]]+w[j];
if(dis[u[j]]>dis[v[j]]+w[j])
dis[u[j]]=dis[v[j]]+w[j]; }
cout<<dis[n]<<endl; }
return ;
}

Queue

 /*
spfa
Memory 256K
Time 32MS
*/
#include <iostream>
#include <queue>
using namespace std;
#define inf 1<<29
#define MAXM 4005
#define MAXV 1005 typedef struct{
int a,b,w,next;
}Edge; Edge edge[MAXM];
int n,m,headlist[MAXV]; void spfa(){
int i,d[MAXV],v,vis[MAXV];
queue <int>q;
for(i=;i<=n;i++){
d[i]=inf;
vis[i]=;
}
d[]=;
vis[]=;
q.push();
while(!q.empty()){
v=q.front();q.pop();
vis[v]=; for(i=headlist[v];i!=-;i=edge[i].next)
if(d[v]+edge[i].w<d[edge[i].b]){
d[edge[i].b]=d[v]+edge[i].w;
if(!vis[edge[i].b]){
vis[edge[i].b]=;
q.push(edge[i].b);
}
}
}
printf("%d\n",d[n]);
} int main(){
int i,a,b,c;
while(~scanf("%d%d",&m,&n)){
for(i=;i<=n;i++) headlist[i]=-;
for(i=;i<=*m;i+=){
scanf("%d%d%d",&a,&b,&c);
edge[i].a=a;
edge[i].b=b;
edge[i].w=c;
edge[i].next=headlist[a];
headlist[a]=i;
edge[i+].a=b;
edge[i+].b=a;
edge[i+].w=c;
edge[i+].next=headlist[b];
headlist[b]=i+;
}
spfa();
}
return ;
}

Til the Cows Come Home (最短路模板题)的更多相关文章

  1. POJ 2387 Til the Cows Come Home --最短路模板题

    Dijkstra模板题,也可以用Floyd算法. 关于Dijkstra算法有两种写法,只有一点细节不同,思想是一样的. 写法1: #include <iostream> #include ...

  2. Til the Cows Come Home(最短路模板题)

    Time Limit:1000MS     Memory Limit:65536KB     64bit IO Format:%lld & %llu Description Bessie is ...

  3. POJ 2387 Til the Cows Come Home(最短路模板)

    题目链接:http://poj.org/problem?id=2387 题意:有n个城市点,m条边,求n到1的最短路径.n<=1000; m<=2000 就是一个标准的最短路模板. #in ...

  4. POJ 2387 Til the Cows Come Home (dijkstra模板题)

    Description Bessie is out in the field and wants to get back to the barn to get as much sleep as pos ...

  5. POJ-2387 Til the Cows Come Home ( 最短路 )

    题目链接: http://poj.org/problem?id=2387 Description Bessie is out in the field and wants to get back to ...

  6. Til the Cows Come Home 最短路Dijkstra+bellman(普通+优化)

    Til the Cows Come Home 最短路Dijkstra+bellman(普通+优化) 贝西在田里,想在农夫约翰叫醒她早上挤奶之前回到谷仓尽可能多地睡一觉.贝西需要她的美梦,所以她想尽快回 ...

  7. poj1511/zoj2008 Invitation Cards(最短路模板题)

    转载请注明出处: http://www.cnblogs.com/fraud/          ——by fraud Invitation Cards Time Limit: 5 Seconds    ...

  8. HDU 5521.Meeting 最短路模板题

    Meeting Time Limit: 12000/6000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others)Total ...

  9. [poj2449]Remmarguts' Date(K短路模板题,A*算法)

    解题关键:k短路模板题,A*算法解决. #include<cstdio> #include<cstring> #include<algorithm> #includ ...

  10. 牛客小白月赛6 I 公交线路 最短路 模板题

    链接:https://www.nowcoder.com/acm/contest/136/I来源:牛客网 题目描述 P市有n个公交站,之间连接着m条道路.P市计划新开设一条公交线路,该线路从城市的东站( ...

随机推荐

  1. input propertyChange

    結合 HTML5 標準事件 oninput 和 IE 專屬事件 onpropertychange 事件來監聽輸入框值變化. oninput 是 HTML5 的標準事件,對於檢測 textarea, i ...

  2. HTML系列(2)基本的HTML标签(一)

        本节介绍基本的HTML标签的使用实例.     (1)h标签: <!DOCTYPE html> <html> <head> <title>示例2 ...

  3. 给嵌入式linux串口添加密码的一些总结

    要添加串口登录密码就需要修改 /etc/inittab 文件的配置 但是不同的开发板情况不一样,有的是没有这个文件的,BusyBox会检查/etc/inittab文件是否存在, 如果此文件不存在, B ...

  4. p2p网络中的NAT穿透技术----常见NAT穿越解决方案

    转:http://blog.csdn.net/cllzw/article/details/46438257 常见NA丁穿越解决方案 NAT技术在缓解IPv4地址紧缺问题.构建防火墙.保证网络安全等方面 ...

  5. 系统封装接口层 cmsis_os

    在这个实时操作系统泛滥的年代,有这么一个系统封装接口层还是蛮有必要的.前些时间偶然间在STM32最新的固件库中就发现了这个系统封装接口,当时就把自己所用的系统进行封装.直到最近KEIL5.0发现其中所 ...

  6. 键盘keyCode

    字母和数字键的键码值(keyCode)   按键 键码 按键 键码 按键 键码 按键 键码 A 65 J 74 S 83 1 49 B 66 K 75 T 84 2 50 C 67 L 76 U 85 ...

  7. 黑色CSS3立体动画菜单

    在线演示 本地下载

  8. JSP DAO(Model)

    示例代码: 1. Users类 package com.po; public class Users { private String username; private String passwor ...

  9. Ubuntu 使用国内apt源

    编辑/etc/apt/source-list deb http://cn.archive.ubuntu.com/ubuntu/ trusty main restricted universe mult ...

  10. MyEclipse Could not create the view: An unexpected exception was thrown解决方案

    问题:电脑突然断电,myeclipse非正常关闭,“Package Explorer”非正常显示,出现错误“Could not create the view: An unexpected excep ...