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复制

  1. 3 4 5
  2. 2
  3. 3
  4. 4
  5. 1 2 1
  6. 1 3 5
  7. 2 3 7
  8. 2 4 3
  9. 3 4 5
输出 #1复制

  1. 8

说明/提示

{样例图形

  1. P2
  2. P1 @--1--@ C1
  3. |
  4. |
  5. 5 7 3
  6. |
  7. | C3
  8. C2 @--5--@
  9. P3 P4

} {说明:

放在4号牧场最优

}

Floyed n^3

Floyed(超时啦 只有63分)

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. const int maxn=,INF=0x3f3f3f3f;
  4. int N,P,C;
  5. int c[maxn],dis[maxn][maxn];
  6. inline void Min(int &x,int y){
  7. if(x>y) x=y;
  8. }
  9. void Floyd(){
  10. for(int k=;k<=P;k++)
  11. for(int i=;i<=P;i++) if(i!=k)
  12. for(int j=;j<=P;j++)if(i!=j&&j!=k)
  13. Min(dis[i][j],dis[i][k]+dis[k][j]);
  14. }
  15. int main()
  16. {
  17. freopen("butter.in","r",stdin);freopen("butter.out","w",stdout);
  18. scanf("%d%d%d",&N,&P,&C);
  19. for(int i=;i<=N;i++){
  20. int x;scanf("%d",&x);
  21. c[x]++;
  22. }
  23. memset(dis,0x3f,sizeof(dis));//这里的一个3f 等于外面的4个3f
  24. for(int i=;i<=P;i++) dis[i][i]=;
  25. for(int i=;i<=C;i++){
  26. int x,y,z;scanf("%d%d%d",&x,&y,&z);
  27. Min(dis[x][y],z);Min(dis[y][x],z);//可能有重边 取更小的那一个
  28. }
  29. Floyd();int ans=0x3f3f3f3f;
  30. for(int i=;i<=P;i++){
  31. int res=;
  32. for(int j=;j<=P;j++) res+=c[j]*dis[j][i];
  33. Min(ans,res);
  34. }
  35. cout<<ans;
  36. return ;
  37. }

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

  1. //正解!
  2. #include<bits/stdc++.h>
  3. #define pa pair<int,int>
  4. #define maxn 805
  5. using namespace std;
  6. vector<int> v[maxn],w[maxn];
  7. priority_queue<pa,vector<pa>,greater<pa> > q;
  8. int dis[maxn],c[maxn];
  9. bool vis[maxn];
  10. int N,P,C;
  11. void Dijkstra(int s){
  12. memset(dis,0x3f,sizeof(dis));dis[s]=;
  13. memset(vis,,sizeof(vis));
  14. while(!q.empty())
  15. q.pop();
  16. q.push(make_pair(,s));
  17. while(!q.empty()){
  18. int x=q.top().second;
  19. q.pop();
  20. if(vis[x]) continue;
  21. vis[x]=;
  22. for(int i=;i<v[x].size();i++){
  23. int y=v[x][i];
  24. if(dis[x]+w[x][i]<dis[y])
  25. {
  26. dis[y]=dis[x]+w[x][i];
  27. q.push(make_pair(dis[y], y));
  28. }
  29. }
  30. }
  31. }
  32. int main()
  33. {
  34. freopen("butter.in","r",stdin);freopen("butter.out","w",stdout);
  35. scanf("%d%d%d",&N,&P,&C);
  36. for(int i=;i<=N;i++){
  37. int x;scanf("%d",&x);
  38. c[x]++;
  39. }
  40. for(int i=;i<=C;i++) {
  41. int x,y,z;scanf("%d%d%d",&x,&y,&z);
  42. v[x].push_back(y);v[y].push_back(x);w[x].push_back(z);w[y].push_back(z);
  43. }
  44. int ans=0x3f3f3f;
  45. for(int i=;i<=P;i++){
  46. Dijkstra(i);int res=;
  47. for(int j=;j<=P;j++)
  48. res+=dis[j]*c[j];
  49. ans=min(ans,res);
  50. }
  51. cout<<ans;
  52. return ;
  53. }

SPFA   上限n*m

  1. #include<bits/stdc++.h>
  2. #define maxn 805
  3. using namespace std;
  4. bool bein[maxn];int dis[maxn];
  5. vector<int> v[maxn],w[maxn];int N,P,C;int c[maxn];
  6. void SPFA(int S){
  7. memset(dis,0x3f,sizeof(dis));
  8. queue<int> q;
  9. dis[S]=;
  10. q.push(S);
  11. bein[S]=true;
  12. while(!q.empty()){
  13. int x=q.front();q.pop();bein[x]=false;
  14. for(int i=;i<v[x].size();i++){
  15. int y=v[x][i];
  16. if(dis[y]>dis[x]+w[x][i]){
  17. dis[y]=dis[x]+w[x][i];
  18. if(!bein[y]){
  19. bein[y]=true;
  20. q.push(y);
  21. }
  22. }
  23. }
  24. }
  25. }
  26. int main()
  27. {
  28. freopen("butter.in","r",stdin);freopen("butter.out","w",stdout);
  29. scanf("%d%d%d",&N,&P,&C);
  30. for(int i=;i<=N;i++){
  31. int x;scanf("%d",&x);
  32. c[x]++;
  33. }
  34. for(int i=;i<=C;i++) {
  35. int x,y,z;scanf("%d%d%d",&x,&y,&z);
  36. v[x].push_back(y);v[y].push_back(x);w[x].push_back(z);w[y].push_back(z);
  37. }
  38. int ans=0x3f3f3f;
  39. for(int i=;i<=P;i++){
  40. SPFA(i);int res=;
  41. for(int j=;j<=P;j++)
  42. res+=dis[j]*c[j];
  43. ans=min(ans,res);
  44. }
  45. cout<<ans;
  46.  
  47. return ;
  48. }

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. dotnet 设计规范 · 结构体定义

    X 不要给结构体默认构造函数 默认的C#编译器也不让开发者定义有默认构造的结构体 X 不要定义易变的属性 易变的属性指的是在调用属性返回值的时候返回的是新的实例,易变的属性会有很多的问题. ✓ 需要确 ...

  2. java基本类型和String之间的转换

    String → 基本类型,除了Character外所有的包装类提供parseXxx(String s)静态方法,用于把一个特定的字符串转换成基本类型变量: 基本类型 → String,String ...

  3. Vue之webpack的entry和output

    一.文件结构 二.index.html <!DOCTYPE html> <html lang="en"> <head> <meta cha ...

  4. Can you find it?——[二分查找]

    Description Give you three sequences of numbers A, B, C, then we give you a number X. Now you need t ...

  5. post提交方式为什么要序列化,而Get提交方式就不用?序列化做了什么?

    这是因为后台能够直接处理的数据格式,是一种经过序列化的键值对数据,比如前端要向后台提交三个参数,分别是a=1,b=2,c=3,那么后台接收到的数据就应该是a=1&b=2&c=3(可以看 ...

  6. H3C配置Trunk端口

  7. 【43.49%】【hdu3308】LCIS

    Time Limit: 6000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission ...

  8. gif 格式

    现在使用gif的场景有很多,很多老师喜欢在课件添加 gif 图片 在开始讲gif之前,先告诉大家 gif 的格式. 请看图片,gif 图分为图片文件头(File Header),gif信息(GIF D ...

  9. 举例理解Hibernate的三种状态(转)

    转自:https://blog.csdn.net/yiguang_820/article/details/79073152 初学Hibernate,了解到Hibernate有三种状态:transien ...

  10. Kali之msf简单的漏洞利用

    1.信息收集 靶机的IP地址为:192.168.173.136 利用nmap工具扫描其开放端口.系统等 整理一下目标系统的相关信息 系统版本:Windows server 2003 开放的端口及服务: ...