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 分) 某地区经过对城镇交通状况的调查,得到现有城镇间快速道路的统计数据,并提出“畅通工程”的目标:使整个地区任何两个城镇间都可以实现快速交通(但不一定有直接的 ...
随机推荐
- Linux新装系统简单指南
也许更好的阅读体验 换源 1. 备份原来的源 sudo cp /etc/apt/sources.list /etc/apt/sources_init.list 2.更换源 先用\(gedit\)打开文 ...
- Oracle数据库基本知识-原理,实例,表空间,用户,表
1.数据库原理及sql 数据库:是人们存放数据,访问数据,操作数据的存储仓库. DB:数据库,按存储结构来组织,存储和管理的数据仓库 DBMS:数据库管理系统,管理数据库的软件 SQL:结构化查询语言 ...
- Scala 系列(三)—— 流程控制语句
一.条件表达式if Scala 中的 if/else 语法结构与 Java 中的一样,唯一不同的是,Scala 中的 if 表达式是有返回值的. object ScalaApp extends App ...
- feign.FeignException: status 400 reading
feign.FeignException: status 400 reading : 请求方调用报错: 服务方被调用报错: 用fegin给redis设置缓存时报错,刚好 卡到8k这个临界点 ,就一直报 ...
- Matlab外观模式
外观模式(Facade Pattern)隐藏系统的复杂性,并向客户端提供了一个客户端可以访问系统的接口.本文以计算机为例,用Matlab代码实现外观模式.计算机包括CPU.内存以及硬盘等这些部件.用户 ...
- 【开发工具】- Atom下载及安装
原文地址:https://www.jianshu.com/p/c112f024e0ab
- Java 之 MyBatis(一)入门
一.Mybatis 框架概述 (1)mybatis 是一个优秀的基于 java 的持久层框架,它内部封装了 jdbc,使开发者只需要关注 sql 语句本身,而不需要花费精力去处理加载驱动.创建连接.创 ...
- Oracle 12c数据库的安装
Oracle一路走来,不知不觉中已经到了12c,最近要用这个新版本了,从oracle的官网上注册了个用户,下载了win版本64位的先试一下. (1)下载安装包 a. 到官网进行下载需要先注册一个Ora ...
- Vue项目整体架构记要
此文记录初次学习Vue的一些记要,可做为参考,导图有些生涩,故意不再加以修复完善,以持初心!
- Others-SAP hybris 介绍
https://wenku.baidu.com/view/6bf4d3a73169a4517623a33d.html