洛谷 P1412 经营与开发 解题报告
P1412 经营与开发
题目描述
\(4X\)概念体系,是指在\(PC\)战略游戏中一种相当普及和成熟的系统概念,得名自4个同样以“\(EX\)”为开头的英语单词。
\(eXplore\)(探索)
\(eXpand\)(拓张与发展)
\(eXploit\)(经营与开发)
\(eXterminate\)(征服)
——维基百科
今次我们着重考虑\(exploit\)部分,并将其模型简化:
你驾驶着一台带有钻头(初始能力值\(w\))的飞船,按既定路线依次飞过\(n\)个星球。
星球笼统的分为2类:资源型和维修型。(\(p\)为钻头当前能力值)
1.资源型:含矿物质量\(a[i]\),若选择开采,则得到\(a[i]*p\)的金钱,之后钻头损耗\(k\)%,即\(p=p*(1-0.01k)\)
2.维修型:维护费用\(b[i]\),若选择维修,则支付\(b[i]*p\)的金钱,之后钻头修复\(c\)%,即\(p=p*(1+0.01c)\)
注:维修后钻头的能力值可以超过初始值(你可以认为是翻修+升级)
金钱可以透支。
请作为舰长的你仔细抉择以最大化收入。
输入输出格式
输入格式:
第一行4个整数\(n,k,c,w\)。
以下\(n\)行,每行2个整数\(type,x\)。
\(type\)为1则代表其为资源型星球,\(x\)为其矿物质含量\(a[i]\);
\(type\)为2则代表其为维修型星球,\(x\)为其维护费用\(b[i]\);
输出格式:
一个实数(保留2位小数),表示最大的收入。
输入输出样例
输入样例#1:
5 50 50 10
1 10
1 20
2 10
2 20
1 30
输出样例#1:
375.00
说明
对于30%的数据 n<=100
另有20%的数据 n<=1000;k=100
对于100%的数据 n<=100000; 0<=k,c,w,a[i],b[i]<=100;保证答案不超过10^9
这个,真的想不到的说啊。。
来手玩一下样例的最大是什么
10(20+(1-0.5)(-10+(1+0.5)30)),选的是2,3,5
通过这个式子我们可以猜到,每次只用保存里面括号的最大值就行了,当不选时就不会产生。在形式上有一点类似秦久韶公式。
也类似于从后往前做DP
这个真没找到什么思维导向性。
我觉得大概可以怎么想,100000?完整存储状态要三维?题目形式还这么简单?手玩手玩手玩找规律。可以积累一下反着做的思维导向。有些题就必须得先读入询问再反向求解的,一般删边的题大多有此套路。
Code:
#include <cstdio>
const int N=100010;
double max(double x,double y){return x>y?x:y;}
int n;
double k,c,w;//开采系数,维修系数,初始能力
double d[N][2],dp[N];
int main()
{
scanf("%d",&n);
scanf("%lf%lf%lf",&k,&c,&w);
c/=100.0,k/=100.0;
for(int i=1;i<=n;i++)
scanf("%lf%lf",d[i],d[i]+1);
for(int i=n;i;i--)
if(d[i][0]==1)
dp[i]=max(dp[i+1],dp[i+1]*(1.0-k)+d[i][1]);
else
dp[i]=max(dp[i+1],dp[i+1]*(1.0+c)-d[i][1]);
printf("%.2f\n",dp[1]*w);
return 0;
}
2018.6.28
洛谷 P1412 经营与开发 解题报告的更多相关文章
- 洛谷 P1412 经营与开发
/* 粘一下开始写的暴力吧 虽然没啥价值 */ #include<iostream> #include<cstdio> #include<cstring> #inc ...
- 洛谷P1412 经营与开发题解
题目链接QWQ这里就不阐述了: 题解部分: 从题面上来看,这是个dp(递推)的题目. 但是dp要满足无后效性,但这个题为了取最值,得考虑从当前开始一直持续到结束的p的影响. 这让我们怎么满足无后效性? ...
- 洛谷_Cx的故事_解题报告_第四题70
1.并查集求最小生成树 Code: #include <stdio.h> #include <stdlib.h> struct node { long x,y,c; ...
- 洛谷 P2317 [HNOI2005]星际贸易 解题报告
P2317 [HNOI2005]星际贸易 题目描述 输入输出格式 输入格式: 输出格式: 如果可以找到这样的方案,那么输出文件output.txt中包含两个整数X和Y.X表示贸易额,Y表示净利润并且两 ...
- 洛谷 P3802 小魔女帕琪 解题报告
P3802 小魔女帕琪 题目背景 从前有一个聪明的小魔女帕琪,兴趣是狩猎吸血鬼. 帕琪能熟练使用七种属性(金.木.水.火.土.日.月)的魔法,除了能使用这么多种属性魔法外,她还能将两种以上属性组合,从 ...
- 洛谷 P2606 [ZJOI2010]排列计数 解题报告
P2606 [ZJOI2010]排列计数 题目描述 称一个\(1,2,...,N\)的排列\(P_1,P_2...,P_n\)是\(Magic\)的,当且仅当对所以的\(2<=i<=N\) ...
- 洛谷1303 A*B Problem 解题报告
洛谷1303 A*B Problem 本题地址:http://www.luogu.org/problem/show?pid=1303 题目描述 求两数的积. 输入输出格式 输入格式: 两个数 输出格式 ...
- 洛谷 P3084 [USACO13OPEN]照片Photo 解题报告
[USACO13OPEN]照片Photo 题目描述 农夫约翰决定给站在一条线上的\(N(1 \le N \le 200,000)\)头奶牛制作一张全家福照片,\(N\)头奶牛编号\(1\)到\(N\) ...
- 洛谷 P1379 八数码难题 解题报告
P1379 八数码难题 题目描述 在3×3的棋盘上,摆有八个棋子,每个棋子上标有1至8的某一数字.棋盘中留有一个空格,空格用0来表示.空格周围的棋子可以移到空格中.要求解的问题是:给出一种初始布局(初 ...
随机推荐
- Scala--包和引入
一.包 同一个包可以定义在多个文件中,你也可以在同一个文件中定义多个包 文件名为:pack.scala package com{ package scala{ package test{ class ...
- 关于docker构建镜像
今天正好看到这一块了,记录一下,希望可以帮助到大家. 构建Dockerfile 先来看一个示例: --------------------------------------------------- ...
- Java基础—常用类之String类
一.String类是什么 public final class String implements java.io.Serializable, Comparable<String>, Ch ...
- Android应用安全之第三方SDK安全
第三方sdk的包括广告.支付.统计.社交.推送,地图等类别,是广告商.支付公司.社交.推送平台,地图服务商等第三方服务公司为了便于应用开发人员使用其提供的服务而开发的工具包,封装了一些复杂的逻辑实现以 ...
- Oracle中,如何查看FRA(Flashback Recovery Area)的利用率
例子: SQL> set linesize 300SQL> select * from V$RECOVERY_AREA_USAGE; FILE_TYPE PERCENT_SPACE_USE ...
- libgdx学习记录9——FreeType,ttf中文显示
前面讲到使用Hireo创建的BitmapFont以显示中文字体.这种方式效率很高,当所要显示的字的总数较少,并且大小比较固定时,可以采用这种方式. 但是这种也有弊端: (1)字体大小不能随意设置,当放 ...
- [CF1062F]Upgrading Cities[拓扑排序]
题意 一张 \(n\) 点 \(m\) 边的 \(DAG\) ,问有多少个点满足最多存在一个点不能够到它或者它不能到. \(n,m\leq 3\times 10^5\) 分析 考虑拓扑排序,如果 \( ...
- pycharm自动生成头文件注释
1.在file->settings->file and code templates->python script即可自定制pycharm创建文件自动生成的头文件注释信息 2.创建p ...
- R语言学习 第五篇:字符串操作
文本数据存储在字符向量中,字符向量的每个元素都是字符串,而非单独的字符.在R中,可以使用双引号,或单引号表示字符. 一,字符串中的字符数量 函数nchar()用于获得字符串中的字符数量: > s ...
- 基于AngularJs的单页面程序
基于AngularJs的单页面程序 在Abpzero的后台管理系统是一个AngularJs的单页面程序.当你登陆后,系统会跳转到"ApplicationController",然后 ...