【香甜的黄油 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】的更多相关文章

  1. 洛谷P1828 香甜的黄油 Sweet Butter

    P1828 香甜的黄油 Sweet Butter 241通过 724提交 题目提供者JOHNKRAM 标签USACO 难度普及+/提高 提交  讨论  题解 最新讨论 我的SPFA为什么TLE.. 为 ...

  2. P1828 香甜的黄油 Sweet Butter 最短路 寻找一个点使得所有点到它的距离之和最小

    P1828 香甜的黄油 Sweet Butter 闲来无事 写了三种最短路(那个Floyed是不过的) 题目描述 农夫John发现做出全威斯康辛州最甜的黄油的方法:糖.把糖放在一片牧场上,他知道N(1 ...

  3. [最短路]P1828 香甜的黄油 Sweet Butter

    题目描述 农夫John发现做出全威斯康辛州最甜的黄油的方法:糖.把糖放在一片牧场上,他知道N(1<=N<=500)只奶牛会过来舔它,这样就能做出能卖好价钱的超甜黄油.当然,他将付出额外的费 ...

  4. P1828 香甜的黄油 Sweet Butter

    对于这道洛谷ac而我整了一下午的codevs的题,我也是很绝望啊. 原因是队列数组开小了我勒个去???我说STL怎么能过 题目描述 农夫John发现做出全威斯康辛州最甜的黄油的方法:糖.把糖放在一片牧 ...

  5. [LUOGU] P1828 香甜的黄油 Sweet Butter

    题目描述 农夫John发现做出全威斯康辛州最甜的黄油的方法:糖.把糖放在一片牧场上,他知道N(1<=N<=500)只奶牛会过来舔它,这样就能做出能卖好价钱的超甜黄油.当然,他将付出额外的费 ...

  6. P1828 香甜的黄油 Sweet Butter (spfa)

    题目描述 农夫John发现做出全威斯康辛州最甜的黄油的方法:糖.把糖放在一片牧场上,他知道N(1<=N<=500)只奶牛会过来舔它,这样就能做出能卖好价钱的超甜黄油.当然,他将付出额外的费 ...

  7. P1828 [USACO3.2]香甜的黄油 Sweet Butter

    题目描述 农夫$John$发现做出全威斯康辛州最甜的黄油的方法:糖.把糖放在一片牧场上,他知道$N(1\leqslant N\leqslant 500)$只奶牛会过来舔它,这样就能做出能卖好价钱的超甜 ...

  8. USACO Section 3.2 香甜的黄油 Sweet Butter

    本题是多源最短路问题 但使用弗洛伊德算法会超时 而因为边数目比较少 所以用队列优化后的迪杰斯特拉算法可以通过 #include<iostream> #include<cstring& ...

  9. 香甜的黄油 Sweet Butter

    原题链接:https://www.luogu.org/problem/show?pid=1828#sub 经典的最短路问题. 各位不要被题目条件迷惑了,牧场想象成点,道路想象成边,奶牛所在的位置想象成 ...

随机推荐

  1. acwing 471. 棋盘 解题记录

    题解地址  https://www.acwing.com/problem/content/description/473/ 有一个m×m的棋盘,棋盘上每一个格子可能是红色.黄色或没有任何颜色的. 你现 ...

  2. 2019-2020-1 20199305《Linux内核原理与分析》第六周作业

    系统调用的三层机制(下) (一)给MenuOS增加命令 (1)打开虚拟机,首先用rm -rf menu指令删除当前的menu目录,然后用git clone重新克隆一个新版本的menu,进入menu,运 ...

  3. (day65)作业

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  4. 央行辟谣未发行“DC/EP”和“DCEP” 法定数字货币仍在测试阶段

    http://www.sohu.com/a/354709423_100157595 近期,中国央行再度就法定数字货币发布公告,指出目前系统仍处于研究测试过程中,市场上交易“DC/EP”或“DCEP”均 ...

  5. 在Unity中使用自定义宏

    最近写AVG工具时有这样的功能需求,AVG的角色可以支持动态的Spine动画,当没有Spine动画时采用默认的立绘图片替代. 这时在脚本中就可以采用自定义的宏来实现: 例如: #if VNSpine ...

  6. keras RAdam优化器使用教程, keras加载模型包含自定义优化器报错 如何解决?

    本文首发于个人博客https://kezunlin.me/post/c691f02b/,欢迎阅读最新内容! python keras RAdam tutorial and load custom op ...

  7. 【51Nod1769】Clarke and math2(数论,组合数学)

    [51Nod1769]Clarke and math2(数论,组合数学) 题面 51Nod 题解 考虑枚举一个\(i_k\),枚举一个\(i\),怎么计算\(i_k\)对\(i\)的贡献. 把\(\f ...

  8. 5-网宿CDN客户端推流NGB

    网宿NGB调度系统(类似httpdns原理)从服务端分发给客户端推流IP,实现基于APP realip精准调度模式. 参考官网介绍:https://www.wangsu.com/content/det ...

  9. angular版聊天室|仿微信界面IM聊天|NG2+Node聊天实例

    一.项目介绍 运用angular+angular-cli+angular-router+ngrx/store+rxjs+webpack+node+wcPop等技术实现开发的仿微信angular版聊天室 ...

  10. 自定义Vue组件打包、发布到npm以及使用

    本文将帮助:将自己写的Vue组件打包到npm进行代码托管,以及正常发布之后如何使用自己的组件. 本文讲述的仅仅是最基础的实现,其他复杂的操作需要非常熟悉webpack的相关知识,作者将继续学习. 先附 ...