(Java实现) 美元汇率
时空限制 1000ms/128MB
题目背景
此处省略maxint+1个数
题目描述
在以后的若干天里戴维将学习美元与德国马克的汇率。编写程序帮助戴维何时应买或卖马克或美元,使他从100美元开始,最后能获得最高可能的价值。
输入输出格式
输入格式:
输入文件的第一行是一个自然数N,1≤N≤100,表示戴维学习汇率的天数。
接下来的N行中每行是一个自然数A,1≤A≤1000。第i+1行的A表示预先知道的第i+1天的平均汇率,在这一天中,戴维既能用100美元买A马克也能用A马克购买100美元。
输出格式:
输出文件的第一行也是唯一的一行应输出要求的钱数(单位为美元,保留两位小数)。
注意:考虑到实数算术运算中进位的误差,结果在正确结果0.05美元范围内的被认为是正确的,戴维必须在最后一天结束之前将他的钱都换成美元。
输入输出样例
输入样例#1:
5
400
300
500
300
250
输出样例#1:
266.67
说明
样例解释 (无需输出)
Day 1 … changing 100.0000 美元= 400.0000 马克
Day 2 … changing 400.0000 马克= 133.3333 美元
Day 3 … changing 133.3333 美元= 666.6666 马克
Day 5 … changing 666.6666 马克= 266.6666 美元
import java.util.Scanner;
public class meiyuanhuilv {
	public static void main(String[] args) {
		Scanner sc =new Scanner(System.in);
		int n = sc.nextInt();
		double money=100;
		int [] num = new int [n+1];
		int temp = 0;//0时兑换马克,1时兑换美元
		for (int i = 1; i < num.length; i++) {
			num[i]=sc.nextInt();
		}
		for (int i = 1; i < num.length-1; i++) {
			if(i==num.length-2 && temp==0){
				if(num[i]>num[i+1]){
					money *=num[i];
					money/=num[i+1];
				}
				else{
					break;
				}
			}
			if(i==num.length-2 && temp==1){
				int a  = Math.min(num[i], num[i+1]);
				money /=a;
				break;
			}
			if(temp==0){
				if(num[i+1]>num[i]){
					continue;
				}
				else{
					money=money*num[i];
					temp=1;
				}
			}
			else if(temp==1){
				if(num[i+1]<num[i]){
					continue;
				}
				else{
					money = money/num[i];
					temp=0;
				}
			}
		}
		System.out.printf("%.2f",money);
	}
}
(Java实现) 美元汇率的更多相关文章
- 洛谷1968美元汇率 dp
		P1968 美元汇率 dp 题目描述 在以后的若干天里戴维将学习美元与德国马克的汇率.编写程序帮助戴维何时应买或卖马克或美元,使他从100美元开始,最后能获得最高可能的价值. 输入输出格式 输入格式: ... 
- 洛谷P1968 美元汇率[2017年4月计划 动态规划02]
		P1968 美元汇率 题目背景 此处省略maxint+1个数 题目描述 在以后的若干天里戴维将学习美元与德国马克的汇率.编写程序帮助戴维何时应买或卖马克或美元,使他从100美元开始,最后能获得最高可能 ... 
- 洛谷P1968 美元汇率
		题目背景 此处省略maxint+1个数 题目描述 在以后的若干天里戴维将学习美元与德国马克的汇率.编写程序帮助戴维何时应买或卖马克或美元,使他从100美元开始,最后能获得最高可能的价值. 输入输出格式 ... 
- 洛谷——1968 美元汇率(DP)
		题目背景 此处省略maxint+1个数 题目描述 在以后的若干天里戴维将学习美元与德国马克的汇率.编写程序帮助戴维何时应买或卖马克或美元,使他从100美元开始,最后能获得最高可能的价值. 输入输出格式 ... 
- AC日记——美元汇率 洛谷 P1988
		题目背景 此处省略maxint+1个数 题目描述 在以后的若干天里戴维将学习美元与德国马克的汇率.编写程序帮助戴维何时应买或卖马克或美元,使他从100美元开始,最后能获得最高可能的价值. 输入输出格式 ... 
- P1968 美元汇率
		题目背景 此处省略maxint+1个数 题目描述 在以后的若干天里戴维将学习美元与德国马克的汇率.编写程序帮助戴维何时应买或卖马克或美元,使他从100美元开始,最后能获得最高可能的价值. 输入输出格式 ... 
- 洛谷——P1968 美元汇率
		https://www.luogu.org/problem/show?pid=1968#sub 题目背景 此处省略maxint+1个数 题目描述 在以后的若干天里戴维将学习美元与德国马克的汇率.编写程 ... 
- luogu 1968 美元汇率
		https://www.luogu.org/problemnew/show/P1968 定义二维数组f[ ][ ],f[i][1]表示在第i天将马克变为美元,f[i][2]表示在第i天将美元变为马克. ... 
- 洛谷 p1968 美元汇率 题解
		传送门 美元由马克转化,马克由美元转化 求最大美元 每一天只有2种选择 ①:不转化另一货币 ②:转化另一货币 典型01背包 可以开一个二维数组f[100][3] F[i][1]表示前i天获得最大美元 ... 
随机推荐
- Linux文件系统基本结构
			(1)Linux文件系统为一个倒转的单根树状结构: (2)文件系统的根为“/”: (3)文件系统严格区分大小写: (4)路径使用“/”分割(windows使用“\”): 当前工作目录 (1)每个she ... 
- MySQL 入门(4):锁
			摘要 在这篇文章中,我将从上一篇的一个小例子开始,跟你介绍一下InnoDB中的行锁. 在这里,会涉及到一个概念:两阶段加锁协议. 之后,我会介绍行锁中的S锁和X锁,以及这两种锁的作用. 但是我们会发现 ... 
- printf小结
			下午健身前和lxt兄弟讨论了一个关于 printf 输出的问题,恰巧以前见过类似的,回来写一个收获总结. 首先看一个这样一个例子 #include<cstdio> int i; int m ... 
- Zookeeper入门一篇就够了
			谈点分布式 什么是分布式呢? 起初,我们的应用流量比较小,所有东西全部部署在一个服务器,比如全部丢给一个tomcat来处理,顶多做一个tomcat的多节点部署多分,再挂一台Nginx做一下负载均衡就O ... 
- Springboot 上传CSV文件并将数据存入数据库
			.xml文件依赖配置 <!--csv依赖 --> <dependency> <groupId>org.apache.commons</groupId> ... 
- 你不知道的事---SringCloud的feign的继承特性
			前言 说起SpringChoud的feign大家用过的都说好.Feign是Netflix开发的声明式.模板化的HTTP客户端.对于我们微服务来说,微服务之间的api调用,使用feign来说是再方便不过 ... 
- 弹性式数据集RDD
			弹性式数据集RDD  一.RDD简介二.创建RDD 2.1 由现有集合创建 2.2 引用外部存储系统中的数据集 2.3 textFile & who ... 
- 必须返回对象时,别妄想返回其reference 【Effective C++ 条款21】
			class Rational { public: Rational(, ) : n(numerator), d(denominator) { printf("Rational Constru ... 
- 情人节闷在家里做画( 安卓统计图MPAndroidChart开发 )
			有些时候觉得一个人挺好的,可以更自由安排自己的时间: 有些时候觉得有个人挺好的,很多事情一个人做起来太没意思了,纵使心中澎湃,倾听的独有自己. 废话少说,直接上图 MPAndroidChart是啥 一 ... 
- 201771010120   苏浪浪  面向对象程序设计(Java)第10周
			1.实验目的与要求 (1) 理解泛型概念: (2) 掌握泛型类的定义与使用: (3) 掌握泛型方法的声明与使用: (4) 掌握泛型接口的定义与实现: (5)了解泛型程序设计,理解其用途. 2.实验 ... 
