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 分) 某地区经过对城镇交通状况的调查,得到现有城镇间快速道路的统计数据,并提出“畅通工程”的目标:使整个地区任何两个城镇间都可以实现快速交通(但不一定有直接的 ...
随机推荐
- CF241E Flights 差分约束
传送门 差分约束永远是Itst最烂的图论知识点没有之一qwq 先用dfs把在\(1\)到\(N\)的路径上的所有点都拿出来,其他的点和边状态任意都不会影响答案. 然后考虑设\(dis_i\)表示从\( ...
- Spring-Cloud之Sleuth链路追踪-8
一.Spring Cloud Sleuth 是Spring Cloud 的一个组件,它的主要功能是在分布式系统中提供服务链路追踪的解决方案. 二.为什么需要Spring Cloud Sleuth? 微 ...
- ADO.net(内置类区别)随记
Ado.net使用流程 SqlConnection->open->SqlCommand(sqlstring,conn)->(ExcuteNonQuery \ExecuteScalar ...
- 使用NODEJS实现JSONP的实例
JSONP与JSON只有一字之差,我们在使用Jquery的Ajax调用的时候也是使用相同的方法来调用,两者的区别几乎只在于使用的dataType这个属性的不同.但是实际上JSON和JSONP是完全不同 ...
- prometheus2.0 联邦的配置
参考:https://blog.51cto.com/lee90/2062252 官网对于联邦的介绍:https://prometheus.io/docs/prometheus/latest/feder ...
- 二 python并发编程之多进程实现
一 multiprocessing模块介绍 二 process类的介绍 三 process类的使用 四 守护进程 五 进程同步(锁) 六 队列 七 管道 八 共享数据 九 信号量 十 事件 十一 进程 ...
- 【初识算法】- AC算法
原文地址:https://www.cnblogs.com/jily/p/6250716.html 一.原理 AC自动机首先将模式组记录为Trie字典树的形式,以节点表示不同状态,边上标以字母表中的字符 ...
- Web网站实现facebook登录
一.登录facebook开发者中心:https://developers.facebook.com 二.创建应用编号,如下图: 三.添加产品选择Facebook登录,如下图: 四.facebbok登录 ...
- 原生js ajax与jquery ajax的区别
原生js ajax的调用: ajax({ type : "get", url : "02_ajax_get.txt", data : { "userN ...
- Java 之 Maven 常用命令
一.Maven 常用命令 在 cmd 中可以通过一系列的 maven 命令对我们的 maven 工程进行编译.测试.运行.打包.安装和部署. 1.compile 命令 compile 是 maven ...