P1828 香甜的黄油 Sweet Butter

闲来无事 写了三种最短路(那个Floyed是不过的)

题目描述

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

农夫John很狡猾。像以前的Pavlov,他知道他可以训练这些奶牛,让它们在听到铃声时去一个特定的牧场。他打算将糖放在那里然后下午发出铃声,以至他可以在晚上挤奶。

农夫John知道每只奶牛都在各自喜欢的牧场(一个牧场不一定只有一头牛)。给出各头牛在的牧场和牧场间的路线,找出使所有牛到达的路程和最短的牧场(他将把糖放在那)

输入格式

第一行: 三个数:奶牛数N,牧场数(2<=P<=800),牧场间道路数C(1<=C<=1450)

第二行到第N+1行: 1到N头奶牛所在的牧场号

第N+2行到第N+C+1行: 每行有三个数:相连的牧场A、B,两牧场间距离D(1<=D<=255),当然,连接是双向的

输出格式

一行 输出奶牛必须行走的最小的距离和

输入输出样例

输入 #1复制

3 4 5
2
3
4
1 2 1
1 3 5
2 3 7
2 4 3
3 4 5
输出 #1复制

8

说明/提示

{样例图形

          P2
P1 @--1--@ C1
|
|
5 7 3
|
| C3
C2 @--5--@
P3 P4

} {说明:

放在4号牧场最优

}

Floyed n^3

Floyed(超时啦 只有63分)

#include<bits/stdc++.h>
using namespace std;
const int maxn=,INF=0x3f3f3f3f;
int N,P,C;
int c[maxn],dis[maxn][maxn];
inline void Min(int &x,int y){
if(x>y) x=y;
}
void Floyd(){
for(int k=;k<=P;k++)
for(int i=;i<=P;i++) if(i!=k)
for(int j=;j<=P;j++)if(i!=j&&j!=k)
Min(dis[i][j],dis[i][k]+dis[k][j]);
}
int main()
{
freopen("butter.in","r",stdin);freopen("butter.out","w",stdout);
scanf("%d%d%d",&N,&P,&C);
for(int i=;i<=N;i++){
int x;scanf("%d",&x);
c[x]++;
}
memset(dis,0x3f,sizeof(dis));//这里的一个3f 等于外面的4个3f
for(int i=;i<=P;i++) dis[i][i]=;
for(int i=;i<=C;i++){
int x,y,z;scanf("%d%d%d",&x,&y,&z);
Min(dis[x][y],z);Min(dis[y][x],z);//可能有重边 取更小的那一个
}
Floyd();int ans=0x3f3f3f3f;
for(int i=;i<=P;i++){
int res=;
for(int j=;j<=P;j++) res+=c[j]*dis[j][i];
Min(ans,res);
}
cout<<ans;
return ;
}

Dijkstra  只能用于有正权边的图   可有正环 不能有负环   Dijkstra n+mlogm    (n可以忽略不计)

//正解!
#include<bits/stdc++.h>
#define pa pair<int,int>
#define maxn 805
using namespace std;
vector<int> v[maxn],w[maxn];
priority_queue<pa,vector<pa>,greater<pa> > q;
int dis[maxn],c[maxn];
bool vis[maxn];
int N,P,C;
void Dijkstra(int s){
memset(dis,0x3f,sizeof(dis));dis[s]=;
memset(vis,,sizeof(vis));
while(!q.empty())
q.pop();
q.push(make_pair(,s));
while(!q.empty()){
int x=q.top().second;
q.pop();
if(vis[x]) continue;
vis[x]=;
for(int i=;i<v[x].size();i++){
int y=v[x][i];
if(dis[x]+w[x][i]<dis[y])
{
dis[y]=dis[x]+w[x][i];
q.push(make_pair(dis[y], y));
}
}
}
}
int main()
{
freopen("butter.in","r",stdin);freopen("butter.out","w",stdout);
scanf("%d%d%d",&N,&P,&C);
for(int i=;i<=N;i++){
int x;scanf("%d",&x);
c[x]++;
}
for(int i=;i<=C;i++) {
int x,y,z;scanf("%d%d%d",&x,&y,&z);
v[x].push_back(y);v[y].push_back(x);w[x].push_back(z);w[y].push_back(z);
}
int ans=0x3f3f3f;
for(int i=;i<=P;i++){
Dijkstra(i);int res=;
for(int j=;j<=P;j++)
res+=dis[j]*c[j];
ans=min(ans,res);
}
cout<<ans;
return ;
}

SPFA   上限n*m

#include<bits/stdc++.h>
#define maxn 805
using namespace std;
bool bein[maxn];int dis[maxn];
vector<int> v[maxn],w[maxn];int N,P,C;int c[maxn];
void SPFA(int S){
memset(dis,0x3f,sizeof(dis));
queue<int> q;
dis[S]=;
q.push(S);
bein[S]=true;
while(!q.empty()){
int x=q.front();q.pop();bein[x]=false;
for(int i=;i<v[x].size();i++){
int y=v[x][i];
if(dis[y]>dis[x]+w[x][i]){
dis[y]=dis[x]+w[x][i];
if(!bein[y]){
bein[y]=true;
q.push(y);
}
}
}
}
}
int main()
{
freopen("butter.in","r",stdin);freopen("butter.out","w",stdout);
scanf("%d%d%d",&N,&P,&C);
for(int i=;i<=N;i++){
int x;scanf("%d",&x);
c[x]++;
}
for(int i=;i<=C;i++) {
int x,y,z;scanf("%d%d%d",&x,&y,&z);
v[x].push_back(y);v[y].push_back(x);w[x].push_back(z);w[y].push_back(z);
}
int ans=0x3f3f3f;
for(int i=;i<=P;i++){
SPFA(i);int res=;
for(int j=;j<=P;j++)
res+=dis[j]*c[j];
ans=min(ans,res);
}
cout<<ans; return ;
}

P1828 香甜的黄油 Sweet Butter 最短路 寻找一个点使得所有点到它的距离之和最小的更多相关文章

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

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

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

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

  3. P1828 香甜的黄油 Sweet Butter

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

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

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

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

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

  6. 【香甜的黄油 Sweet Butter】

    [香甜的黄油 Sweet Butter] 洛谷P1828 https://www.luogu.org/problemnew/show/P1828 JDOJ 1803 https://neooj.com ...

  7. 洛谷 P1828 【香甜的黄油 Sweet Butter】

    这道题应该就是模板题了吧qwq. 统计每一个牧场的放糖的情况,选择最优的即可 有亿点水的绿题. #include <bits/stdc++.h> using namespace std; ...

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

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

  9. 洛谷 题解 P1828 【香甜的黄油 Sweet Butter】

    潇洒の开始 第一步:食用头文件和定义变量, 变量干什么用的说的很清楚 #include<iostream> #include<cstdio> #include<cstri ...

随机推荐

  1. 析构函数 p157

    析构函数 确保对象的各部分被正确的清除,及做一些用户指定的其他清理工作. 当对象超出它的作用域时,编译器将自动调用析构函数:手动用new在堆上分配的对象空间,需要调用'delete 对象地址'进行手动 ...

  2. H3C HDLC配置

  3. thinkPHP框架中执行原生SQL语句的方法

    这篇文章主要介绍了thinkPHP框架中执行原生SQL语句的方法,结合实例形式分析了thinkPHP中执行原生SQL语句的相关操作技巧,并简单分析了query与execute方法的使用区别,需要的朋友 ...

  4. WPF 使用 Composition API 做高性能渲染

    在 WPF 中很多小伙伴都会遇到渲染性能的问题,虽然 WPF 的渲染可以甩浏览器渲染几条街,但是还是支持不了游戏级的渲染.在 WPF 使用的 DX 只是优化等级为 9 和 DX 9 差不多的性能,微软 ...

  5. 2018-2-13-C#-解析-sln-文件

    title author date CreateTime categories C# 解析 sln 文件 lindexi 2018-2-13 17:23:3 +0800 2018-2-13 17:23 ...

  6. 备战省赛组队训练赛第五场(UPC)

    中石油比赛链接 CF题目链接 E:博客 G:李继朋  博客 H:苗学林  贺振原 J:博客  苗学林 机房白给队全方位题解:A B E G I J

  7. 2018-11-5-win10-uwp-异步转同步

    title author date CreateTime categories win10 uwp 异步转同步 lindexi 2018-11-05 10:18:40 +0800 2018-2-13 ...

  8. 用C++获取屏幕上某点的颜色

    假定坐标点 x=50,y=50. 输出 RGB 用 16 进制数.Afxwin.h 你建项目时可得.#include <Afxwin.h>#include <Windows.h> ...

  9. 关于axios的一些封装

    关于Axios的封装 为何需要在封装 应用场景,项目中涉及100个AJAX请求,其中: 1.其中60个需要在请求头header设置token headers: {token: token}用于权限校验 ...

  10. P1919 FFT加速高精度乘法

    P1919 FFT加速高精度乘法 传送门:https://www.luogu.org/problemnew/show/P1919 题意: 给出两个n位10进制整数x和y,你需要计算x*y. 题解: 对 ...