luoguP1576 最小花费
两种做法:
1.边的权值为手续费z,从b向a跑最短路,边跑边处理答案
2.边的权值为汇率,从a向b跑最短路,边跑边处理答案
#include<cstdio>
#include<iostream>
#include<queue>
using namespace std;
queue<double>q;
double path[],n,m,z,dis[],vis[];
int x,y,A,B,k;
struct node{
int u,v,nxt;
double w;
}edge[];
void add(int xx,int yy,double zz)
{
edge[++k].u =xx;
edge[k].v =yy;
edge[k].w =-zz/;
edge[k].nxt =path[xx];
path[xx]=k;
}
int main()
{
scanf("%lf%lf",&n,&m);
for(int i=;i<=m;++i)
{
scanf("%d%d%lf",&x,&y,&z);
add(y,x,z);add(x,y,z);
}
scanf("%d%d",&A,&B);
for(int i=;i<=n;++i)
dis[i]=0x3fff;
dis[B]=;vis[B]=;
q.push(B);
while(!q.empty())
{
int now=q.front() ;
q.pop() ;
vis[now]=; for(int i=path[now];i;i=edge[i].nxt )
{
if(dis[edge[i].v]>dis[edge[i].u]/edge[i].w)
{
dis[edge[i].v]=dis[edge[i].u]/edge[i].w;
if(!vis[edge[i].v])
{
q.push(edge[i].v );
vis[edge[i].v]=;
}
}
}
}
printf("%.8lf",dis[A]);
return ;
}
做法1
#include<iostream>
#include<cstdio>
#include<queue>
#include<cstring>
using namespace std;
const int N=,M=1e6;
struct node{
int u,v,nxt;
double w;
}e[M<<];
int n,m,num,s,t,head[N];
double dis[N];
bool vis[N];
queue<int>q;
int qread()
{
int x=;
char ch=getchar();
while(ch<'' || ch>'')ch=getchar();
while(ch>='' && ch<=''){x=x*+ch-'';ch=getchar();}
return x;
}
void Add(int u,int v,int w)
{
e[++num].u=u;
e[num].v=v;
e[num].w=1.0-w/100.0;
e[num].nxt=head[u];
head[u]=num;
}
void SPFA()
{
for(int i=;i<=n;++i)
dis[i]=100000.0;
dis[t]=;vis[t]=;
q.push(t);
int u,v;
while(!q.empty())
{
u=q.front();q.pop();
vis[u]=;
for(int i=head[u];i;i=e[i].nxt)
{
v=e[i].v;
if(dis[v]>dis[u]/e[i].w)
{
dis[v]=dis[u]/e[i].w;
if(!vis[v])
{
vis[v]=;
q.push(v);
}
}
}
}
}
int main()
{
scanf("%d%d",&n,&m);
int u,v,w;
for(int i=;i<=m;i++)
{
u=qread();v=qread();w=qread();
Add(u,v,w);
Add(v,u,w);
}
scanf("%d%d",&s,&t);
SPFA();
printf("%.8lf\n",dis[s]);
return ;
}
做法2
luoguP1576 最小花费的更多相关文章
- 把一个序列转换成严格递增序列的最小花费 CF E - Sonya and Problem Wihtout a Legend
//把一个序列转换成严格递增序列的最小花费 CF E - Sonya and Problem Wihtout a Legend //dp[i][j]:把第i个数转成第j小的数,最小花费 //此题与po ...
- 把一个序列转换成非严格递增序列的最小花费 POJ 3666
//把一个序列转换成非严格递增序列的最小花费 POJ 3666 //dp[i][j]:把第i个数转成第j小的数,最小花费 #include <iostream> #include < ...
- 第四届CCF软件能力认证(CSP2015) 第五题(最小花费)题解
[问题描述] C国共有$n$个城市.有$n-1$条双向道路,每条道路连接两个城市,任意两个城市之间能互相到达.小R来到C国旅行,他共规划了$m$条旅行的路线, 第$i$条旅行路线的起点是$s_i$,终 ...
- 九度OJ 1086 最小花费--动态规划
题目地址:http://ac.jobdu.com/problem.php?pid=1086 题目描述: 在某条线路上有N个火车站,有三种距离的路程,L1,L2,L3,对应的价格为C1,C2,C3.其对 ...
- hdoj 3072 Intelligence System【求scc&&缩点】【求连通所有scc的最小花费】
Intelligence System Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Othe ...
- ccf 201503-5 最小花费 这题交上去只有10分嗨!求大佬的题解啊
问题描述 C国共有n个城市.有n-1条双向道路,每条道路连接两个城市,任意两个城市之间能互相到达.小R来到C国旅行,他共规划了m条旅行的路线,第i条旅行路线的起点是si,终点是ti.在旅行过程中,小R ...
- [LeetCode] Minimum Cost to Merge Stones 混合石子的最小花费
There are N piles of stones arranged in a row. The i-th pile has stones[i] stones. A move consists ...
- 1344:【例4-4】最小花费 dijkstra
1344:[例4-4]最小花费 Dijkstra (1)a [ i ] [ j ] 存转账率(..转后所得率..) (2)dis [ i ] 也就是 a [ 起点 ] [ i ] (3)f [ i ] ...
- PTA 7-1 畅通工程之局部最小花费问题(35 分)
7-1 畅通工程之局部最小花费问题(35 分) 某地区经过对城镇交通状况的调查,得到现有城镇间快速道路的统计数据,并提出“畅通工程”的目标:使整个地区任何两个城镇间都可以实现快速交通(但不一定有直接的 ...
随机推荐
- vue SPA设计 history hash
<body> <h3>Histort api</h3> <a class="api a">a,html</a> < ...
- 实战Go内存泄露【转】
最近解决了我们项目中的一个内存泄露问题,事实再次证明pprof是一个好工具,但掌握好工具的正确用法,才能发挥好工具的威力,不然就算你手里有屠龙刀,也成不了天下第一,本文就是带你用pprof定位内存泄露 ...
- 换个语言学一下 Golang (9)——结构体和接口
基本上到这里的时候,就是上了一个台阶了.Go的精华特点即将展开. 结构体定义 上面我们说过Go的指针和C的不同,结构体也是一样的.Go是一门删繁就简的语言,一切令人困惑的特性都必须去掉. 简单来讲,G ...
- 练习bloc , 动画
有点意思, import 'package:flutter/material.dart'; import 'package:rxdart/rxdart.dart'; main()=>runApp ...
- 英语foteball足球foteball单词
现代足球起源地是在英格兰.传说在11世纪,英格兰与丹麦之间有过一场战争,战争结束后,英格兰人在清理战争废墟时发现一个丹麦入侵者的头骨,出于愤恨,他们便用脚去踢这个头骨,一群小孩见了便也来踢,不过他们发 ...
- ECharts大屏可视化【词云,堆积柱状图,折线图,南丁格尔玫瑰图】
一.简介 参考ECharts快速入门:https://www.cnblogs.com/yszd/p/11166048.html 二.代码实现 <!DOCTYPE html> <htm ...
- 转:ajax的AntiForgery和Authorize 以及ajax登录例子
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明.本文链接:https://blog.csdn.net/ashcn2001/article/det ...
- 五、Linux_ping命令
ping命令用法为:“ping 参数 目标主机”.其中参数为零到多个,目标主机可以是IP或者域名. 1.每隔0.6秒ping一次,一共ping 5次: [root@aiezu.com ~]# ping ...
- git 上传代码流程
1.首先下载git,安装到本地 2.点击启动git bash.exe 3.现在本地创建一个文件夹 后cd 进入该文件夹内 4.在文件夹内输入 git init 是此文件夹变成一个git本地仓库 5 ...
- Java入门(二)——泛型
如果你写过前端,可能会经常写一下关于变量类型的判断,比如:typeof fn === 'function'之类的代码.因为JavaScript作为一门弱类型语言,类型的判断往往需要开发人员自己去检查. ...