【香甜的黄油 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. MongoDB学习笔记(一、MongoDB入门)

    目录: 为什么要使用nosql mongo的简介 应用场景 入门demo 为什么要使用nosql: 随着互联网的发展,用户数量激增,访问量的上涨,传统的关系型数据库的性能也趋于瓶颈. 关系型数据库难以 ...

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

    操作系统的秘密 (一)计算机的三大法宝 存储程序计算机: 函数调用堆栈机制: 中断机制. (二)堆栈 (1)堆栈的作用 记录函数调用框架: 传递函数参数: 保存返回值的地址: 提供局部变量存储空间. ...

  3. js函数只执行一次,函数重写,变量控制与闭包三种做法

    一.情景需求 调用后台接口需要附带token信息,那么在每个请求的头部添加token的做法就不太优雅了:一个网站请求100次,那就得写添加100次token,假设某天接口有所变动,改起来就十分麻烦了. ...

  4. Flink1.7.2安装部署的几种方式

    原文链接:https://blog.csdn.net/a_drjiaoda/article/details/88037282 前言:Flink的运行一般分为三种模式,即local.Standalone ...

  5. app自动化测试初体验

    一.appium环境开启 1.开启MUMU模拟器/真机(真机需要开启“USB开发调试模式”),使用命令行adb devices检查设备是否正常连接 2.开启appium 双击运行appium应用 正常 ...

  6. oracle视图和索引

    视图和索引 视图 视图的作用 控制数据访问.简化查询.避免重复访问相同的数据 视图的优点 限制用户只能通过视图检索数据,用户看不到底层基表 注意事项 视图可以理解为临时表,会随着真实表的数据变化而自动 ...

  7. 恢复Chrome 78以上版本的地址栏https和www显示

    Google在Chrome不知道是脑子抽抽还是怎么回事,非要把https://www从地址栏中隐藏掉. htttps://www.pool.ntp.org就给你显示个pool.ntp.org,这分明就 ...

  8. 2、Hibernate持久化编写

    一.对于hibernate中的PO编写规则: 1. 必须提供一个无参数的public构造方法   2. 所有属性要private ,对外提供public 的get/set方法   3. 在PO类必须提 ...

  9. springcloud微服务多节点高性能、高可用、高并发部署

    1. 共有三个服务 discovery服务,domain服务,gateway服务. discovery服务是用来注册其他服务的,作为服务治理用. domain服务是主业务服务. gateway服务是所 ...

  10. nodejs通过钉钉群机器人推送消息

    nodejs 通过钉钉群机器人推送消息 Intro 最近在用 nodejs 写爬虫,之前的 nodejs 爬虫代码用 js 写的,感觉可维护性太差,也没有智能提示,于是把js改用ts(typescri ...