潇洒の开始

第一步:食用头文件和定义变量,

变量干什么用的说的很清楚

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int n,p,c,i,j,x,y,t,min1,head,tail,tot,u;
int a[][],b[],dis[],num[],w[][],team[];//team为队列,dis为距离,num为邻接点个数,a存相邻点
bool exist[];//exist是存在的意思,确定某个元素是否存在
int main()

第二步:正常的输入

    cin>>n>>p>>c;//奶牛数,牧场数,牧场间的道路数
for(i=; i<=p; i++)
{
b[i]=;
num[i]=;
for(j=; j<=p; j++)
w[i][j]=0x7fffffff/;//第i到第j个牧场的路程初始化为无穷
}

将两点之间的距离变为超大超大的数,酱紫好比较的啦

第三步:正常的输入加存储

for(i=; i<=n; i++)
cin>>b[i];//输入奶牛所在的牧场号
for(i=; i<=c; i++) //邻接矩阵存储,采用循环队列能够降低队列大小,队列长度只需开到2*n+5即可。
{
cin>>x>>y>>t;//相连牧场AB和两牧场间的距离
w[x][y]=t;//保存x到y间的距离
a[x][++num[x]]=y;//存相邻点,在num原有的基础上加一,并将y点存入
a[y][++num[y]]=x;//存相邻点,在num原有的基础上加一,并将x点存入
w[y][x]=w[x][y];//因为是双向连通的,所以两牧场间的距离相等
}

详细解释代码里面说的很清楚了,在啰嗦一下,双向的很重要

用地接斯科拉的哥们们注意了。

第四步:初始化minn

min1=0x7fffffff/3;//初始化min

最后一步:gao chao 预警

for(i=; i<=p; i++)
{
for(j=; j<=p; j++) dis[j]=0x7fffffff/;
//memset(team,0,sizeof(team)); //队列数组初始化
//memset(exist,false,sizeof(exist)); //exist标志初始化
dis[i]=;
team[]=i;
head=;
tail=;
exist[i]=true; //起始点入队
while(head!=tail)
{
head++;
head=((head-)%)+; //循环队列处理
u=team[head];
exist[u]=false;
for(j=; j<=num[u]; j++) //num数组储存的为当前点所相邻的点的个数
if (dis[a[u][j]]>dis[u]+w[u][a[u][j]])
{
dis[a[u][j]]=dis[u]+w[u][a[u][j]];
if (!exist[a[u][j]])//如果该点没有被拿出,就进行处理
{
tail++;
tail=((tail-)%)+;
team[tail]=a[u][j];
exist[a[u][j]]=true;//拿出该数
}
}
}
tot=;
for(j=; j<=n; j++)
tot+=dis[b[j]];//累加路程并计算
if (tot<min1) min1=tot;//找最小
}
cout<<min1;
return ;

初始化我是去掉了,因为定义在int main()外面是不需要再次清零的

然后就是类似手打的队列,挨个比较找到小的就马上替换,重要的是没有被用过就处理

再就是挨个比较找最小值就好了

完整代码:

完整代码

完美の结束

(这是我之前做的题,现在才拿出来写题解忘得差不多了,写的不好请多多谅解QWQ) (看的这么累,不点个赞再走)

洛谷 题解 P1828 【香甜的黄油 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

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

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

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

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

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

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

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

  7. 【香甜的黄油 Sweet Butter】

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

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

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

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

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

随机推荐

  1. Kafka启用SASL_PLAINTEXT动态配置JAAS文件的几种方式

    Kafka是广泛使用消息服务,很多情况下关于认证部分我都是默认的配置,也就是不需要用户名/密码,也不配置证书.在内网或者在项目组内部可以,但是设计的跨部门时一般处于安全考虑都需要加上认证,防止kafk ...

  2. Django:信号的使用

    信号 Django中提供了"信号调度",用于在框架执行操作时解耦.通俗来讲,就是一些动作发生的时候,信号允许特定的发送者去提醒一些接受者. 应用:比如插入数据到数据库,插入之前写日 ...

  3. react diff

    传统diff 通过循环递归对节点的依次对比,复杂度是O(n3) react diff react对传统diff进行了优化,将复杂度降为O(n) react基于这几个前提对diff进行了优化: 忽略跨层 ...

  4. Radmin入侵

    Radmin (Remote Administrator)是一款屡获殊荣的远程控制软件,它将远程控制.外包服务组件.以及网络监控结合到一个系统里,提供目前为止最快速.强健而安全的工具包 生成被控端 点 ...

  5. Synchronized可重入锁分析

    可重入锁又称递归锁,是指在同一个线程在外层方法获取锁的时候,再进入该线程的内层方法会自动获取锁(前提是锁对象必须是同一对象或者class), 不会因为之前已经获取过还没实方而发生阻塞.即同一线程可执行 ...

  6. 图说jdk1.8新特性(2)--- Lambda

    简要说明 jdk常用函数式接口 Predicate @FunctionalInterface public interface Predicate<T> { boolean test(T ...

  7. js 动态创建 全局变量(转载)

    转载来源 https://blog.csdn.net/stevenzhong900610/article/details/40857087 https://www.jb51.net/article/8 ...

  8. Python_类的继承与方法重写

    1.新建子类时,括号内要传入继承的父类名 2.super()方法:自动寻找当前类的父类,并调用父类的构造函数,初始化属性值 class Cup: #构造函数,初始化属性值 def __init__(s ...

  9. vue父组件触发子组件方法

    比如应用场景是弹窗中的组件,想要点弹窗时更新该组件展示对应记录的的值 methods: { edit (record) { this.mdl = Object.assign({}, record) t ...

  10. Linux操作系统故障排除之Grub信息被删除

    Linux操作系统故障排除之Grub信息被删除 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. [root@yinzhengjie ~]# hexdump -C /dev/sda - ...