POJ 2240 Arbitrage 最短路线
来源:互联网 发布:大智慧炒股软件 编辑:程序博客网 时间:2024/05/16 08:21
Arbitrage
Time Limit: 1000MS Memory Limit: 65536KTotal Submissions: 22267 Accepted: 9455
Description
Arbitrage is the use of discrepancies in currency exchange rates to transform one unit of a currency into more than one unit of the same currency. For example, suppose that 1 US Dollar buys 0.5 British pound, 1 British pound buys 10.0 French francs, and 1 French franc buys 0.21 US dollar. Then, by converting currencies, a clever trader can start with 1 US dollar and buy 0.5 * 10.0 * 0.21 = 1.05 US dollars, making a profit of 5 percent.
Your job is to write a program that takes a list of currency exchange rates as input and then determines whether arbitrage is possible or not.
Your job is to write a program that takes a list of currency exchange rates as input and then determines whether arbitrage is possible or not.
Input
The input will contain one or more test cases. Om the first line of each test case there is an integer n (1<=n<=30), representing the number of different currencies. The next n lines each contain the name of one currency. Within a name no spaces will appear. The next line contains one integer m, representing the length of the table to follow. The last m lines each contain the name ci of a source currency, a real number rij which represents the exchange rate from ci to cj and a name cj of the destination currency. Exchanges which do not appear in the table are impossible.
Test cases are separated from each other by a blank line. Input is terminated by a value of zero (0) for n.
Test cases are separated from each other by a blank line. Input is terminated by a value of zero (0) for n.
Output
For each test case, print one line telling whether arbitrage is possible or not in the format "Case case: Yes" respectively "Case case: No".
Sample Input
3USDollarBritishPoundFrenchFranc3USDollar 0.5 BritishPoundBritishPound 10.0 FrenchFrancFrenchFranc 0.21 USDollar3USDollarBritishPoundFrenchFranc6USDollar 0.5 BritishPoundUSDollar 4.9 FrenchFrancBritishPound 10.0 FrenchFrancBritishPound 1.99 USDollarFrenchFranc 0.09 BritishPoundFrenchFranc 0.19 USDollar0
Sample Output
Case 1: YesCase 2: No
Source
Ulm Local 1996
货币转换,看看有没有利润,也就是这个货币折腾一圈,看看自身有没有增值,Floyd
ac代码:
#include <cstdio>#include <cstring>#include <iostream>#include <algorithm>#define INF 0x3f3f3f3fusing namespace std;double map[35][35];char mon[50][50];int time=1,n,m;int search(char *s){int i;for(i=1;i<=n;i++){if(!strcmp(s,mon[i]))return i;}return -1;}int flyod(){int i,j,k;for(k=1;k<=n;k++){for(i=1;i<=n;i++){for(j=1;j<=n;j++){if(map[i][j] < (map[i][k]*map[k][j]))map[i][j]=map[i][k]*map[k][j];}}}return 0;}int main(){int i,j,k,flag;int p,q;double run;char s1[50],s2[50];while(~scanf("%d",&n),n){//printf("n====%d\n",n);for(i=0;i<=n;i++)for(j=0;j<=n;j++){if(i==j)map[i][j]=1;elsemap[i][j]=0;}for(i=1;i<=n;i++){scanf("%s",mon[i]);//printf("%s\n",mon[i]);}scanf("%d",&m);for(i=0;i<m;i++){scanf("%s %lf %s",s1,&run,s2);//printf("%s %lf %s\n",s1,run,s2);p=search(s1);q=search(s2);map[p][q]=run;}flyod();flag=0;for(i=1;i<=n&&!flag;i++){if(map[i][i]>1.0)flag=1;}printf("Case %d: ",time++);if(flag)printf("Yes\n");elseprintf("No\n");}return 0;}
1 0
- POJ 2240 Arbitrage 最短路线
- poj 2240 Arbitrage(最短路径)
- 初级->图算法->最短路径 poj 2240 Arbitrage
- POJ 2240 Arbitrage 最短路径 Floyed-Warshall
- poj 2240 Arbitrage 最短路
- POJ 2240 Arbitrage(最短路)
- POJ-2240 Arbitrage(最短路)
- POJ 3660 Cow Contest 最短路线
- poj 2240 Arbitrage(最短路+Bellman-Ford)
- POJ 2240 Arbitrage(最短路 Floyd)
- poj-2240-Arbitrage-spfa-最短路
- POJ 2240 Arbitrage(最短路 套汇)
- POJ 2240 Arbitrage(最短路Floyed)
- poj-2240-Arbitrage-最短路 BF
- poj 2240 Arbitrage 【最短路&&floyd】
- POJ 2240 Arbitrage(最短路)
- POJ 2240Arbitrage(最短路floyd)
- POJ 2240 Arbitrage(Floyd最短路)
- JAVASCRIPT(js)简单动态秒表程序设计代码
- Pod FailedScheduling
- 一步步构建大型网站架构
- JSP--tomacat安装测试(windows10)
- Android开发笔记(一百三十七)自定义行为Behavior
- POJ 2240 Arbitrage 最短路线
- 记录自己使用瓦片图的坑
- JavaEE框架整合视频
- [tensorflow]TypeError: Fetch argument .+ has invalid type
- GPU 共享内存bank冲突(shared memory bank conflicts)
- 1125. Chain the Ropes 解析
- Android中自定义属性attrs.xml、TypedArray的使用
- 关于addShutdownHook()
- 父类委托机制[2]父类委托机制真的安全吗