POJ 1860 Currency Exchange【bellman_ford判断是否有正环——基础入门】
链接:
| Time Limit: 1000MS | Memory Limit: 30000K | |
| Total Submissions: 16244 | Accepted: 5656 |
Description
Each point has its own exchange rates, exchange rate of A to B is the quantity of B you get for 1A. Also each exchange point has some commission, the sum you have to pay for your exchange operation. Commission is always collected in source currency.
For example, if you want to exchange 100 US Dollars into Russian Rubles at the exchange point, where the exchange rate is 29.75, and the commission is 0.39 you will get (100 - 0.39) * 29.75 = 2963.3975RUR.
You surely know that there are N different currencies you can deal with in our city. Let us assign unique integer number from 1 to N to each currency. Then each exchange point can be described with 6 numbers: integer A and B - numbers of currencies it exchanges,
and real RAB, CAB, RBA and CBA - exchange rates and commissions when exchanging A to B and B to A respectively.
Nick has some money in currency S and wonders if he can somehow, after some exchange operations, increase his capital. Of course, he wants to have his money in currency S in the end. Help him to answer this difficult question. Nick must always have non-negative
sum of money while making his operations.
Input
of the corresponding exchange point - in specified above order. Numbers are separated by one or more spaces. 1<=S<=N<=100, 1<=M<=100, V is real number, 0<=V<=103.
For each point exchange rates and commissions are real, given with at most two digits after the decimal point, 10-2<=rate<=102, 0<=commission<=102.
Let us call some sequence of the exchange operations simple if no exchange point is used more than once in this sequence. You may assume that ratio of the numeric values of the sums at the end and at the beginning of any simple sequence of the exchange operations
will be less than 104.
Output
Sample Input
3 2 1 20.0
1 2 1.00 1.00 1.00 1.00
2 3 1.10 1.00 1.10 1.00
Sample Output
YES
Source
题意:
兑换货币有一定的兑换率 r 和佣金 c
如果货币 A 兑换 B 兑换率是 r ,佣金是 c
那么value 个 A 可以换成 (value-c)*r 个 B
每个兑换点能两种货币双向兑换,但是兑换比例和佣金不同
输入时注意一下
问:最后如果能够使得自己的钱变多,则输出 YES
否则输出 NO
算法:bellman_ford 判断是否有正环
思路:
看是否有正环,如果有正环,则说明可以通过这个正环
使得自己的钱不断增多。
code:
| 1860 | Accepted | 140K | 32MS | C++ | 2217B |
/***********************************************************
A Accepted 140 KB 0 ms C++ 1454 B
题意:一个城市有 N 种货币, 有 M 个兑换点
兑换货币有一定的兑换率 r 和佣金 c
如果货币 A 兑换 B 兑换率是 r ,佣金是 c
那么value 个 A 可以换成 (value-c)*r 个 B
每个兑换点能两种货币双向兑换,但是兑换比例和佣金不同
输入时注意一下
问:最后如果能够使得自己的钱变多,则输出 YES
否则输出 NO
算法:bellman_ford 判断是否有正环
思路:直接按照输入顺序加双向边后,套用 bellman_ford模板
看是否有正环,如果有正环,则说明可以通过这个正环
使得自己的钱不断增多。
***********************************************************/
#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std; const int maxn = 110;
double d[maxn];
int n, m, index; //index 表示开始拥有的货币的编号
double money; struct Edge{
int u,v;
double r,c; //r:兑换率; c:佣金; 如果拿value个u换v ,则得到的 v :(value-c)*r
}edge[maxn*2]; bool bellman_ford()
{
for(int i = 0; i <= n; i++) d[i] = 0; //初始没有其他货币
d[index] = money; //开始拥有的货币 for(int i = 1; i < n; i++) //n-1 轮松弛操作
{
bool flag = true; //标记是否松弛
for(int j = 0; j < m; j++)
{
int u = edge[j].u;
int v = edge[j].v;
double r = edge[j].r;
double c = edge[j].c; if(d[v] < (d[u]-c)*r) //松弛【也就是走这条路,钱变多】
{
d[v] = (d[u]-c)*r;
flag = false;
}
} if(flag) return false; //当前都无法松弛了,肯定没有正环了,直接返回
} for(int i = 0; i < m; i++) //判断是否能继续松弛,如果能,就说明有正环
{
if(d[edge[i].v] < (d[edge[i].u] - edge[i].c)*edge[i].r)
return true;
}
return false;
} int main()
{
while(scanf("%d%d%d%lf", &n,&m,&index,&money) != EOF)
{
int k = 0;
int u,v;
double r1,c1,r2,c2;
for(int i = 1; i <= m; i++) //双向兑换
{
scanf("%d%d%lf%lf%lf%lf", &u,&v,&r1,&c1,&r2,&c2);
edge[k].u = u;
edge[k].v = v;
edge[k].r = r1;
edge[k++].c = c1; edge[k].u = v;
edge[k].v = u;
edge[k].r = r2;
edge[k++].c = c2;
}
m = 2*m;
if(bellman_ford()) printf("YES\n"); //如果有正环
else printf("NO\n"); }
}
POJ 1860 Currency Exchange【bellman_ford判断是否有正环——基础入门】的更多相关文章
- poj1860 Currency Exchange(spfa判断是否存在正环)
题意:有m个货币交换点,每个点只能有两种货币的互相交换,且要给佣金,给定一开始的货币类型和货币数量,问若干次交换后能否让钱增加. 思路:spfa求最长路,判断是否存在正环,如果存在则钱可以在环中一直增 ...
- poj - 1860 Currency Exchange Bellman-Ford 判断正环
Currency Exchange POJ - 1860 题意: 有许多货币兑换点,每个兑换点仅支持两种货币的兑换,兑换有相应的汇率和手续费.你有s这个货币 V 个,问是否能通过合理地兑换货币,使得你 ...
- POJ 1860 Currency Exchange(最短路&spfa正权回路)题解
题意:n种钱,m种汇率转换,若ab汇率p,手续费q,则b=(a-q)*p,你有第s种钱v数量,问你能不能通过转化让你的s种钱变多? 思路:因为过程中可能有负权值,用spfa.求是否有正权回路,dis[ ...
- 最短路(Bellman_Ford) POJ 1860 Currency Exchange
题目传送门 /* 最短路(Bellman_Ford):求负环的思路,但是反过来用,即找正环 详细解释:http://blog.csdn.net/lyy289065406/article/details ...
- POJ 1860 Currency Exchange / ZOJ 1544 Currency Exchange (最短路径相关,spfa求环)
POJ 1860 Currency Exchange / ZOJ 1544 Currency Exchange (最短路径相关,spfa求环) Description Several currency ...
- POJ 1860 Currency Exchange + 2240 Arbitrage + 3259 Wormholes 解题报告
三道题都是考察最短路算法的判环.其中1860和2240判断正环,3259判断负环. 难度都不大,可以使用Bellman-ford算法,或者SPFA算法.也有用弗洛伊德算法的,笔者还不会SF-_-…… ...
- POJ 1860 Currency Exchange 最短路+负环
原题链接:http://poj.org/problem?id=1860 Currency Exchange Time Limit: 1000MS Memory Limit: 30000K Tota ...
- POJ 1860 Currency Exchange【bellman-Ford模板题】
传送门:http://poj.org/problem?id=1860 题意:给出每两种货币之间交换的手续费和汇率,求出从当前货币s开始交换回到s,能否使本金增多. 思路:bellman-Ford模板题 ...
- POJ 1860 Currency Exchange(Bellman-Ford)
https://vjudge.net/problem/POJ-1860 题意: 有多种货币,可以交换,有汇率并且需要支付手续费,判断是否能通过不断交换使本金变多. 思路: Bellman-Ford算法 ...
随机推荐
- 【 D3.js 入门系列 --- 5 】 怎样加入坐标轴
本人的个人博客为: www.ourd3js.com csdn博客为: blog.csdn.net/lzhlzz 转载请注明出处.谢谢. 第3节中做了一个图标.但没有为它加入一个对应的坐标轴. ...
- iOS 之UIBezierPath
代码地址如下:http://www.demodashi.com/demo/11602.html 在之前的文章中,由于用到过UIBezierPath这个类,所以这里就对这个类进行简单的记录一下,方便自己 ...
- Activity具体解释(生命周期、启动方式、状态保存,全然退出等)
一.什么是Activity? 简单的说:Activity就是布满整个窗体或者悬浮于其它窗体上的交互界面. 在一个应用程序中通常由多个Activity构成,都会在Manifest.xml中指定一个主的A ...
- MATLAB读取黑白图像显示却是黑色,24位深转8位深黑白图像解决方法
1.24位深转8位深: ps将24位深原图.png保存为GIF图256即为8位,再将8位gif图转为需要的.png,即转为8位深png图. 2.MATLAB读取黑白图像显示几乎全为黑色: 这是最近处理 ...
- NodeJS淘宝 CNPM 镜像
原文地址:http://npm.taobao.org/ 设置NPM镜像(前提已安装NodeJS): npm config set registry https://registry.npm.taoba ...
- win10 rabbitMQ的安装与测试
安装 1.首先,下载并运行Erlang for Windows 安装程序 (地址:http://www.erlang.org/downloads)下载完毕并安装(注意:安装目录请选择默认目录) 2.下 ...
- mac使用git管理Github
工欲善其事,必先利其器. 在OS X Yosemite 10.10.3安装最新版本号Xcode.在terminal下能够发现git已经被安装. ~ mesut$ git --version git v ...
- Atitit.常用语言的常用内部api 以及API兼容性对源码级别可移植的重要性 总结
Atitit.常用语言的常用内部api 以及API兼容性对源码级别可移植的重要性 总结 1.1. 要兼容的重要语言api1 1.2. 常用基础api分类 core api1 1.3. 比较常用的扩展库 ...
- Atitit.uml2 api 的编程代码实现设计uml开发 使用eclipse jar java 版本
Atitit.uml2 api 的编程代码实现设计uml开发 使用eclipse jar java 版本 1. clipse提供了UML的底层Java包, 1 2. MDTUML2Getting St ...
- 复杂可编程逻辑器件CPLD的基本结构
复杂可编程逻辑器件CPLD的基本结构 文章出处:czhlcai 发布时间: 2008/12/08 | 6911 次阅读 专业薄膜开关打样工厂,12小时加急出货 1.基于乘积项的CPLD结构 CPL ...