Arbitrage(POJ 2240)

本文介绍了一种使用Floyd算法解决货币兑换仲裁问题的方法,通过构建货币兑换率图,判断是否存在盈利的货币转换路径。

~题目链接~

http://poj.org/problem?id=2240

~题目~

                                                                                                                Arbitrage
Time Limit: 1000MS Memory Limit: 65536K
Total Submissions: 13552 Accepted: 5709

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. 

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.

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

3
USDollar
BritishPound
FrenchFranc
3
USDollar 0.5 BritishPound
BritishPound 10.0 FrenchFranc
FrenchFranc 0.21 USDollar

3
USDollar
BritishPound
FrenchFranc
6
USDollar 0.5 BritishPound
USDollar 4.9 FrenchFranc
BritishPound 10.0 FrenchFranc
BritishPound 1.99 USDollar
FrenchFranc 0.09 BritishPound
FrenchFranc 0.19 USDollar

0

Sample Output

Case 1: Yes
Case 2: No

~解析~

给你一种货币,进行若干次兑换后看是否盈利。

简单的floyd算法

 1 #include<iostream>
 2 #include<string>
 3 #include<map>
 4 
 5 using namespace std;
 6 
 7 int n,m,i,j,k;
 8 double t,turn[31][31];
 9 string s,s1,s2;
10 map<string,int>Q;
11 
12 void floyd()
13 {
14     for(i=1; i<=n; i++)
15         for(j=1; j<=n; j++)
16             for(k=1; k<=n; k++)
17                 if(turn[j][k]<turn[j][i]*turn[i][k])
18                     turn[j][k]=turn[j][i]*turn[i][k];
19     return;
20 }
21 
22 int main()
23 {
24     int T=0;
25     while(cin>>n && n!=0)
26     {
27         T++;
28         for(i=1; i<=n; i++)
29         {
30             cin>>s;
31             Q[s]=i;
32             turn[i][i]=1;//兑换率为1
33         }
34         cin>>m;
35         for(i=1; i<=m; i++)
36         {
37             cin>>s1>>t>>s2;
38             turn[Q[s1]][Q[s2]]=t;
39         }
40 
41         floyd();
42 
43         int flag=1;
44         for(i=1; i<=n; i++)
45             if(turn[i][i]>1)
46             {
47                 flag=0;
48                 break;
49             }
50 
51         if(!flag)
52             cout<<"Case "<<T<<": Yes"<<endl;
53         else
54             cout<<"Case "<<T<<": No"<<endl;
55     }
56 
57     return 0;
58 }
View Code

 

 

 

转载于:https://www.cnblogs.com/guoyongzhi/p/3306079.html

本研究基于扩展卡尔曼滤波(EKF)方法,构建了一套用于航天器姿态与轨道协同控制的仿真系统。该系统采用参数化编程设计,具备清晰的逻辑结构和详细的代码注释,便于用户根据具体需求调整参数。所提供的案例数据可直接在MATLAB环境中运行,无需额外预处理步骤,适用于计算机科学、电子信息工程及数学等相关专业学生的课程设计、综合实践或毕业课题。 在航天工程实践中,精确的姿态与轨道控制是保障深空探测、卫星组网及空间设施建设等任务成功实施的基础。扩展卡尔曼滤波作为一种适用于非线性动态系统的状态估计算法,能够有效处理系统模型中的不确定性与测量噪声,因此在航天器耦合控制领域具有重要应用价值。本研究实现的系统通过模块化设计,支持用户针对不同航天器平台或任务场景进行灵活配置,例如卫星轨道维持、飞行器交会对接或地外天体定点着陆等控制问题。 为提升系统的易用性与教学适用性,代码中关键算法步骤均附有说明性注释,有助于用户理解滤波器的初始化、状态预测、观测更新等核心流程。同时,系统兼容多个MATLAB版本(包括2014a、2019b及2024b),可适应不同的软件环境。通过实际操作该仿真系统,学生不仅能够深化对航天动力学与控制理论的认识,还可培养工程编程能力与实际问题分析技能,为后续从事相关技术研究或工程开发奠定基础。 资源来源于网络分享,仅用于学习交流使用,请勿用于商业,如有侵权请联系我删除!
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值