Til the Cows Come Home (最短路模板题)
个人心得:模板题,不过还是找到了很多问题,真的是头痛,为什么用dijkstra算法book【1】=1就错了.....
纠结中....
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
* 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
Sample Input
5 5
1 2 20
2 3 30
3 4 20
4 5 20
1 5 100
Sample Output
90
Hint
There are five landmarks.
OUTPUT DETAILS:
Bessie can get home by following trails 4, 3, 2, and 1.
#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 (最短路模板题)的更多相关文章
- POJ 2387 Til the Cows Come Home --最短路模板题
Dijkstra模板题,也可以用Floyd算法. 关于Dijkstra算法有两种写法,只有一点细节不同,思想是一样的. 写法1: #include <iostream> #include ...
- Til the Cows Come Home(最短路模板题)
Time Limit:1000MS Memory Limit:65536KB 64bit IO Format:%lld & %llu Description Bessie is ...
- POJ 2387 Til the Cows Come Home(最短路模板)
题目链接:http://poj.org/problem?id=2387 题意:有n个城市点,m条边,求n到1的最短路径.n<=1000; m<=2000 就是一个标准的最短路模板. #in ...
- 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 ...
- 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 ...
- Til the Cows Come Home 最短路Dijkstra+bellman(普通+优化)
Til the Cows Come Home 最短路Dijkstra+bellman(普通+优化) 贝西在田里,想在农夫约翰叫醒她早上挤奶之前回到谷仓尽可能多地睡一觉.贝西需要她的美梦,所以她想尽快回 ...
- poj1511/zoj2008 Invitation Cards(最短路模板题)
转载请注明出处: http://www.cnblogs.com/fraud/ ——by fraud Invitation Cards Time Limit: 5 Seconds ...
- HDU 5521.Meeting 最短路模板题
Meeting Time Limit: 12000/6000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)Total ...
- [poj2449]Remmarguts' Date(K短路模板题,A*算法)
解题关键:k短路模板题,A*算法解决. #include<cstdio> #include<cstring> #include<algorithm> #includ ...
- 牛客小白月赛6 I 公交线路 最短路 模板题
链接:https://www.nowcoder.com/acm/contest/136/I来源:牛客网 题目描述 P市有n个公交站,之间连接着m条道路.P市计划新开设一条公交线路,该线路从城市的东站( ...
随机推荐
- samtools的基本用法
1.sam,bam的格式转换: $samtools view -sb file.sam >file.bam $samtools view -sb file.sam -o file.bam #sa ...
- php数组函数-array_keys()
array_keys()函数返回包含数组中所有键名的一个新数组 如果提供了第二个参数,则返回键值为该值得键名 如果strict参数指定为true,则php会使用全等(===)来严格检查键值的 数据类型 ...
- C++中容器的使用(二)
第一章容器 第1条:慎重选择容器类型. 标准STL序列容器:vector.string.deque和list. 标准STL关联容器:set.multiset.map和multimap. 非标准序列容器 ...
- MYSQL数据库字段命名及设计规范
1.设计原则 1) 标准化和规范化数据的标准化有助于消除数据库中的数据冗余.标准化有好几种形式,但 Third Normal Form(3NF)通常被认为在性能.扩展性和数据完整性方面达到了最好平衡. ...
- python爬虫-韩寒新浪博客博文
博客地址:http://blog.sina.com.cn/s/articlelist_1191258123_0_1.html 爬第一页博文 #-*-coding:utf--*- import re # ...
- 树分治learning
学习了树的点分治,树的边分治似乎因为复杂度过高而并不出众,于是没学 自己总结了一下 有些时候面对一些树上的结构 并且解决的是和路径有关的问题的时候 如果是多个询问 关注点在每次给出两个点,求一些关于这 ...
- 用TinyXml做XML解析示例 TinyXml查找唯一节点及修改节点操作
// 读者对象:对TinyXml有一定了解的人.本文是对TinyXml工具的一些知识点的理解. // 1 TinyXml中对TiXmlNode进行了分类,是用一个枚举进行描述的. // enum No ...
- 【转载】JAVA多线程读取、操作List集合
本文转载自:http://blog.csdn.net/wang1989cs/article/details/47663565 import java.util.ArrayList; import ja ...
- 不理解use explanatory variables
- 更改自己iCloud的地区
百度一大堆都是过时的,而且没有用,通过google后发现google+里有一个文章https://plus.google.com/+%E5%90%B4%E5%BF%97%E5%8B%8776/post ...