【香甜的黄油 Sweet Butter】
【香甜的黄油 Sweet Butter】
洛谷P1828
https://www.luogu.org/problemnew/show/P1828
JDOJ 1803
https://neooj.com/oldoj/problem.php?id=1803
一眼就看出来是个最短路,看题目这么短就觉得是个裸的
然后就
真香
我不知道用dijkstra会被卡掉,但是我运气好第一遍写的就是SPFA就过了。这篇题解就给大家分析一下各最短路算法以及这道题为什么适用SPFA。
floyd算法
这个东西轻易不要用,因为是O(n^3)的,很容易就会爆掉,但是真的想用也没问题,看一下数据范围,一般不超过500都可以(如果是100-200的就比较稳了,500以上的还是慎重). 搭配邻接矩阵就很好用。
dijkstra算法
单源最短路最常见的算法,时间复杂度是O(n^2)的,但是这题就不能用
为什么呢????
因为要枚举每个点啊!!那复杂度就是O(n^3)的了,简直是找死......
所以我们只能出其最后一策了
SPFA算法
名字很高大上,事实上的确很快,加了个队列的数据结构,非常好理解,时间复杂度是O(km)(k约等于2)的,跟边的数量有关,适合
稀疏图(边少)
而dj的复杂度跟点有关,所以可以搞
稠密图(边多)
综上所述,这道题的时间复杂度就是O(nmk)的,就可以方方便便地AC了。
TALK LESS,SHOW ME THE CODE.
#include<cstdio>
#include<cstring>
#include<queue>
#include<algorithm>
using namespace std;
int cow,n,m,ans=;
int position[];
int total,to[],value[],naxt[],head[];
int f[],v[];
void add(int x,int y,int z)
{
to[++total]=y;
value[total]=z;
naxt[total]=head[x];
head[x]=total;
}
void spfa(int start)
{
memset(f,0x3f,sizeof(f));
memset(v,,sizeof(v));
queue<int> q;
q.push(start);f[start]=;v[start]=;
while(!q.empty())
{
int x,y;
x=q.front();q.pop();v[x]=;
for(int i=head[x];i;i=naxt[i])
if(f[y=to[i]]>f[x]+value[i])
{
f[y]=f[x]+value[i];
if(v[y]==) v[y]=,q.push(y);
}
}
}
int main()
{
scanf("%d%d%d",&cow,&n,&m);
for(int i=;i<=cow;i++)
scanf("%d",&position[i]);
for(int i=;i<=m;i++)
{
int x,y,z;
scanf("%d%d%d",&x,&y,&z);
add(x,y,z);
add(y,x,z);
}
for(int i=;i<=n;i++)
{
int dist=;
spfa(i);
for(int j=;j<=cow;j++)
dist+=f[position[j]];
ans=min(ans,dist);
}
printf("%d",ans);
return ;
}
学过了Dijkstra堆优化之后,用DIJ也可以AC。
没有学习DIJ堆优化的请进入以下链接~
https://www.cnblogs.com/fusiwei/p/11390537.html
代码如下:
#include<cstdio>
#include<queue>
#include<algorithm>
#include<cstring>
using namespace std;
int n,p,c,ans=1e9;
int pos[];
int tot,to[],val[],nxt[],head[];
int dist[];
priority_queue<pair<int,int> >q;
void add(int x,int y,int z)
{
to[++tot]=y;
val[tot]=z;
nxt[tot]=head[x];
head[x]=tot;
}
void dijkstra(int start)
{
memset(dist,0x3f,sizeof(dist));
dist[start]=;
q.push(make_pair(,start));
while(!q.empty())
{
while(!q.empty() && -q.top().first>dist[q.top().second])
q.pop();
if(q.empty())
return;
int x=q.top().second;
q.pop();
for(int i=head[x];i;i=nxt[i])
{
int y=to[i];
if(dist[y]>dist[x]+val[i])
{
dist[y]=dist[x]+val[i];
q.push(make_pair(-dist[y],y));
}
}
}
}
int main()
{
scanf("%d%d%d",&n,&p,&c);
for(int i=;i<=n;i++)
scanf("%d",&pos[i]);
for(int i=;i<=c;i++)
{
int x,y,z;
scanf("%d%d%d",&x,&y,&z);
add(x,y,z);
add(y,x,z);
}
for(int i=;i<=p;i++)
{
int dis=;
dijkstra(i);
for(int j=;j<=n;j++)
dis+=dist[pos[j]];
ans=min(ans,dis);
}
printf("%d",ans);
return ;
}
【香甜的黄油 Sweet Butter】的更多相关文章
- 洛谷P1828 香甜的黄油 Sweet Butter
P1828 香甜的黄油 Sweet Butter 241通过 724提交 题目提供者JOHNKRAM 标签USACO 难度普及+/提高 提交 讨论 题解 最新讨论 我的SPFA为什么TLE.. 为 ...
- P1828 香甜的黄油 Sweet Butter 最短路 寻找一个点使得所有点到它的距离之和最小
P1828 香甜的黄油 Sweet Butter 闲来无事 写了三种最短路(那个Floyed是不过的) 题目描述 农夫John发现做出全威斯康辛州最甜的黄油的方法:糖.把糖放在一片牧场上,他知道N(1 ...
- [最短路]P1828 香甜的黄油 Sweet Butter
题目描述 农夫John发现做出全威斯康辛州最甜的黄油的方法:糖.把糖放在一片牧场上,他知道N(1<=N<=500)只奶牛会过来舔它,这样就能做出能卖好价钱的超甜黄油.当然,他将付出额外的费 ...
- P1828 香甜的黄油 Sweet Butter
对于这道洛谷ac而我整了一下午的codevs的题,我也是很绝望啊. 原因是队列数组开小了我勒个去???我说STL怎么能过 题目描述 农夫John发现做出全威斯康辛州最甜的黄油的方法:糖.把糖放在一片牧 ...
- [LUOGU] P1828 香甜的黄油 Sweet Butter
题目描述 农夫John发现做出全威斯康辛州最甜的黄油的方法:糖.把糖放在一片牧场上,他知道N(1<=N<=500)只奶牛会过来舔它,这样就能做出能卖好价钱的超甜黄油.当然,他将付出额外的费 ...
- P1828 香甜的黄油 Sweet Butter (spfa)
题目描述 农夫John发现做出全威斯康辛州最甜的黄油的方法:糖.把糖放在一片牧场上,他知道N(1<=N<=500)只奶牛会过来舔它,这样就能做出能卖好价钱的超甜黄油.当然,他将付出额外的费 ...
- P1828 [USACO3.2]香甜的黄油 Sweet Butter
题目描述 农夫$John$发现做出全威斯康辛州最甜的黄油的方法:糖.把糖放在一片牧场上,他知道$N(1\leqslant N\leqslant 500)$只奶牛会过来舔它,这样就能做出能卖好价钱的超甜 ...
- USACO Section 3.2 香甜的黄油 Sweet Butter
本题是多源最短路问题 但使用弗洛伊德算法会超时 而因为边数目比较少 所以用队列优化后的迪杰斯特拉算法可以通过 #include<iostream> #include<cstring& ...
- 香甜的黄油 Sweet Butter
原题链接:https://www.luogu.org/problem/show?pid=1828#sub 经典的最短路问题. 各位不要被题目条件迷惑了,牧场想象成点,道路想象成边,奶牛所在的位置想象成 ...
随机推荐
- MongoDB学习笔记(一、MongoDB入门)
目录: 为什么要使用nosql mongo的简介 应用场景 入门demo 为什么要使用nosql: 随着互联网的发展,用户数量激增,访问量的上涨,传统的关系型数据库的性能也趋于瓶颈. 关系型数据库难以 ...
- Day8 - Python基础8 异常处理、反射、单例模式
本节内容: 1:异常处理 2:反射 3:单例模式 1.异常处理 1.异常简介 在编程过程中为了增加友好性,在程序出现bug时一般不会将错误信息显示给用户,而是现实一个提示的页面,通俗来说就是不让用户 ...
- 201871010102-常龙龙《面向对象程序设计(java)》第十五周学习总结
项目 内容 这个作业属于哪个课程 https://www.cnblogs.com/nwnu-daizh/ 这个作业的要求在哪里 https://www.cnblogs.com/nwnu-daizh/p ...
- 面向对象程序设计(JAVA) 第13周学习指导及要求
2019面向对象程序设计(Java)第13周学习指导及要求 (2019.11.19-2019.11.25) 学习目标 (1) 掌握事件处理的基本原理,理解其用途: (2) 掌握AWT事件模型的工作 ...
- 部署Springboot项目到Linux云服务器
前言 环境:IDEA.Springboot.Maven(自己电脑安装的Maven) 一.打包jar包 检查自己的pom.xml文件下面有无Maven的依赖插件,即有无如下: <build> ...
- 2019csp-s
11.17一切尘埃落定 回来之后一直“沉迷”文化课,不想去面对自己,更多的可能是不敢吧 晃晃悠悠一个星期过去了 其实信息学考完就知道成绩了,很垃圾,不想去想,所以沉迷解析几何无法自拔(但好像也做不对几 ...
- HTML连载43-还原字体和字号、文字界面
一.还原字体和字号 1.利用fireworks切片以及文本添加的功能可以用来定位我们想要的文字是什么字体,行高又是多少,但其实很low,是我们人工挑选出来的. 2.注意点:在企业开发中,如果一个盒子中 ...
- 【nginx启动报错】重启服务器之后nginx启动错
错误信息: # ./nginx nginx: [emerg] open() "/var/run/nginx/nginx.pid" failed (2: No such file ...
- JeeSite | 保存信息修改记录
需求点 在很多场景中信息是不能轻易被修改的,修改时要么需要具备权限,要么需要审批,但是无论是哪种方式,修改前后的数据都是需要留有“案底”的,也就是说关键的信息被修改后是有修改记录的,一般修改记录会记录 ...
- 简单node服务器demo,麻雀虽小,五脏俱全
//本服务器要实现的功能如下: //1.静态资源服务器(能读取静态资源) //2.能接收get请求,并能处理参数 //3.能接收post请求,并能处理参数 const http = require(' ...