AcWing 1127. 香甜的黄油
农夫John发现了做出全威斯康辛州最甜的黄油的方法:糖。
把糖放在一片牧场上,他知道 N 只奶牛会过来舔它,这样就能做出能卖好价钱的超甜黄油。
当然,他将付出额外的费用在奶牛上。
农夫John很狡猾,就像以前的巴甫洛夫,他知道他可以训练这些奶牛,让它们在听到铃声时去一个特定的牧场。
他打算将糖放在那里然后下午发出铃声,以至他可以在晚上挤奶。
农夫John知道每只奶牛都在各自喜欢的牧场(一个牧场不一定只有一头牛)。
给出各头牛在的牧场和牧场间的路线,找出使所有牛到达的路程和最短的牧场(他将把糖放在那)。
数据保证至少存在一个牧场和所有牛所在的牧场连通。
#include<bits/stdc++.h>
using namespace std;
typedef pair<int,int> pp;
int n,k,m,ans=0x3f3f3f3f;
int a[505];
int fir[805],to[2905],nxt[2905],w[2905],num;
int dis[805][805];
bool vis[805];
void add(int x,int y,int z){nxt[++num]=fir[x];fir[x]=num;to[num]=y;w[num]=z;}
priority_queue<pp,vector<pp>,greater<pp> > q;
void dj(int bg)
{
memset(vis,0,sizeof(vis));
q.push(make_pair(0,bg));
dis[bg][bg]=0;
while(q.size()){
int u=q.top().second;
q.pop();
if(vis[u]) continue;
vis[u]=1;
for(int i=fir[u],v;v=to[i],i;i=nxt[i])
{
if(dis[bg][v]>dis[bg][u]+w[i])
{
dis[bg][v]=dis[bg][u]+w[i];
q.push(make_pair(dis[bg][v],v));
}
}
}
}
int main()
{
scanf("%d%d%d",&k,&n,&m);
memset(dis,0x3f,sizeof(dis));
for(int i=1;i<=k;i++)scanf("%d",&a[i]);
for(int i=1;i<=m;i++)
{
int a,b,c;
scanf("%d%d%d",&a,&b,&c);
add(a,b,c);add(b,a,c);
}
for(int i=1;i<=n;i++)
{
dj(i);
int t=0;
for(int j=1;j<=k;j++)t+=dis[i][a[j]];
if(t>0) ans=min(ans,t);
}
printf("%d\n",ans);
return 0;
}
AcWing 1127. 香甜的黄油的更多相关文章
- 洛谷P1828 香甜的黄油 Sweet Butter
		P1828 香甜的黄油 Sweet Butter 241通过 724提交 题目提供者JOHNKRAM 标签USACO 难度普及+/提高 提交 讨论 题解 最新讨论 我的SPFA为什么TLE.. 为 ... 
- Cogs 309. [USACO 3.2] 香甜的黄油  dijkstra,堆,最短路,floyd
		题目:http://cojs.tk/cogs/problem/problem.php?pid=309 309. [USACO 3.2] 香甜的黄油 ★★ 输入文件:butter.in 输出文件 ... 
- Sweet Butter 香甜的黄油
		Sweet Butter 香甜的黄油 题目大意:m个点,n头奶牛,p条边,每一头奶牛在一个点上,一个点可以有多只奶牛,求这样一个点,使得所有奶牛到这个点的距离之和最小. 注释:n<=500 , ... 
- AC日记——香甜的黄油 codevs 2038
		2038 香甜的黄油 USACO 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题解 查看运行结果 题目描述 Description 农夫Jo ... 
- 【香甜的黄油 Sweet Butter】
		[香甜的黄油 Sweet Butter] 洛谷P1828 https://www.luogu.org/problemnew/show/P1828 JDOJ 1803 https://neooj.com ... 
- P1828 香甜的黄油 Sweet Butter 最短路 寻找一个点使得所有点到它的距离之和最小
		P1828 香甜的黄油 Sweet Butter 闲来无事 写了三种最短路(那个Floyed是不过的) 题目描述 农夫John发现做出全威斯康辛州最甜的黄油的方法:糖.把糖放在一片牧场上,他知道N(1 ... 
- 【USACO 3.2.6】香甜的黄油
		[描述] 农夫John发现做出全威斯康辛州最甜的黄油的方法:糖.把糖放在一片牧场上,他知道N(1<=N<=500)只奶牛会过来舔它,这样就能做出能卖好价钱的超甜黄油.当然,他将付出额外的费 ... 
- [最短路]P1828 香甜的黄油 Sweet Butter
		题目描述 农夫John发现做出全威斯康辛州最甜的黄油的方法:糖.把糖放在一片牧场上,他知道N(1<=N<=500)只奶牛会过来舔它,这样就能做出能卖好价钱的超甜黄油.当然,他将付出额外的费 ... 
- P1828 香甜的黄油 Sweet Butter
		对于这道洛谷ac而我整了一下午的codevs的题,我也是很绝望啊. 原因是队列数组开小了我勒个去???我说STL怎么能过 题目描述 农夫John发现做出全威斯康辛州最甜的黄油的方法:糖.把糖放在一片牧 ... 
随机推荐
- Mysql 数据库基本操作
			1.数据库设置密码 [root@db02 scripts]# mysqladmin -uroot password 123 2.使用密码登录 #1.正确的方式(不规范) [root@db02 scri ... 
- linux系统的负载详解
			系统的平均负载 如何理解平均负载  单位时间内,系统处于可运行状态和不可中断状态的平均进程数,也就是平均活跃进程数. 平均负载多少合理 核心数 平均负载 含义 4 2 有50%的cpu是空闲状态,见 ... 
- linux中级之netfilter防火墙(firewalld)
			一.firewalld主要概念 dynamic firewall daemon.支持ipv4和ipv6.Centos7中默认将防火墙从iptables升级为了firewalld.firewalld相对 ... 
- java 计算下面级数之和 1/3+3/5+5/7+...+97/99
			代码实例图:package judgment;/** * 计算下面级数之和 * 1/3+3/5+5/7+...+97/99; */public class Judgment { public stat ... 
- 新晋总监生存指南三——OKR
			一.什么是OKR 书接上文:新晋总监生存指南二--建立指标 OKR在我们团队正循环大图中占有很重的分量,好的OKR实践同时也是上文中数据指标实践的案例.反向论述可以认为,数据指标建设混乱的团队很难运用 ... 
- GO学习-(14) Go语言基础之接口
			Go语言基础之接口 接口(interface)定义了一个对象的行为规范,只定义规范不实现,由具体的对象来实现规范的细节. 接口 接口类型 在Go语言中接口(interface)是一种类型,一种抽象的类 ... 
- Jmeter- 笔记5 - 从响应数据提取信息
			JSON提取器 提取 响应体(response body)里的信息 在需要提取数据的请求下添加 JSON提取器,一个JSON提取器可以写多个json提取器 路径:后置处理器 -> JSON提取器 ... 
- bat使用方法汇总
			前言 由于日常科研工作中使用C/C++比较多,在进行大规模运行时涉及到的批量处理操作较多,遂将目前遇到的情况记录如下,以便查看: 1.for循环 最基本的for循环操作为在一些数中遍历,如下例子.se ... 
- 3D惯导Lidar仿真
			3D惯导Lidar仿真 LiDAR-Inertial 3D Plane Simulator 摘要 提出了最*点*面表示的形式化方法,并分析了其在三维室内同步定位与映射中的应用.提出了一个利用最*点*面 ... 
- postgresql无序uuid性能测试
			无序uuid对数据库的影响 由于最近在做超大表的性能测试,在该过程中发现了无序uuid做主键对表插入性能有一定影响.结合实际情况发现当表的数据量越大,对表插入性能的影响也就越大. 测试环境 Postg ... 
