luoguP1080 国王游戏 (贪心+高精度)
题目链接:https://www.luogu.org/problemnew/show/P1080
参考:https://www.luogu.org/problemnew/solution/P1080
思路:这道题的考点是贪心和高精度。
贪心部分:
…(设这一段乘积为X1) | …(设这一段乘积为Y2) |
---|---|
L1 | R1 |
…(设这一段乘积为X2) | …(设这一段乘积为Y2) |
L2 | R2 |
由上面这张表格可以知道这样的情况时:
第一个人所得的金币数为X1/R1;
第二个人所得的金币数为X1×L1×X2/R2;
所以最小值为 max(X1/R1, X1×L1×X2/R2);
然后交换两个人的位置
…(这一段乘积为X1) | …(这一段乘积为Y2) |
---|---|
L2 | R2 |
…(这一段乘积为X2) | …(这一段乘积为Y2) |
L1 | R1 |
由上面这张表格可以知道交换后的情况时:
第一个人所得的金币数为X1×L2×X2/R1;
第二个人所得的金币数为X1/R2;
所以此时最小值为max(X1×L2×X2/R1, X1/R2);
综合上面两种情况:
如果变换之前的情况要优于变换之后的情况,那么
max(X1/R1, X1×L1×X2/R2) < max(X1×L2×X2/R1, X1/R2);
而X1/R1 < X1×L2×X2/R1 恒成立;
X1×L1×X2/R2 > X1/R2;
所以上述条件成立时
必须有X1×L1×X2/R2 < X1×L2×X2/R1 恒成立;所以化简可得 L1×R1 < L2×R2恒成立。
综上,很容易想到Li×Ri越大的应该排在越后面,所以对数据排个序就行。
另外就是高精度,数据最大可能达到10的4000次方,故需要使用高精度,这种高精度方法是参考的别人的,比较方便巧妙,不需要花费时间进行整数与字符串的转化。
代码如下:
#include<cstdio>
#include<algorithm>
using namespace std; struct node{
int a,b;
bool operator < (const node& other) const{
return a*b<other.a*other.b;
}
}dat[]; int n,in=;
int hp[]; void mul(int k){
for(int i=;i<=in;i++)
hp[i]*=dat[k].a;
for(int i=;i<=in;i++){
hp[i+]+=hp[i]/;
hp[i]%=;
}
in++;
while(hp[in]>){
hp[in+]=hp[in]/;
hp[in]%=;
in++;
}
if(hp[in]==)
in--;
} void div(){
for(int i=in;i>=;i--){
hp[i-]+=((hp[i]%dat[n].b)*);
hp[i]/=dat[n].b;
}
while(hp[in]==)
in--;
} int main(){
scanf("%d",&n);
for(int i=;i<=n;i++)
scanf("%d%d",&dat[i].a,&dat[i].b);
sort(dat+,dat+n+);
hp[]=dat[].a;
for(int i=;i<n;i++)
mul(i);
div();
if(in==)
printf(""); //最终数组长度为0,由于每个人都会得到赏金,故每个人最多分到1赏金
else
for(int i=in;i>=;i--)
printf("%d",hp[i]);
printf("\n");
return ;
}
luoguP1080 国王游戏 (贪心+高精度)的更多相关文章
- [noip2012]国王游戏<贪心+高精度>
题目链接: https://vijos.org/p/1779 https://www.luogu.org/problem/show?pid=1080 http://codevs.cn/problem/ ...
- P1080 国王游戏 贪心 高精度
题目描述 恰逢 HH国国庆,国王邀请nn 位大臣来玩一个有奖游戏.首先,他让每个大臣在左.右手上面分别写下一个整数,国王自己也在左.右手上各写一个整数.然后,让这 nn 位大臣排成一排,国王站在队伍的 ...
- P1080 【NOIP 2012】 国王游戏[贪心+高精度]
题目来源:洛谷 题目描述 恰逢 H国国庆,国王邀请n 位大臣来玩一个有奖游戏.首先,他让每个大臣在左.右手上面分别写下一个整数,国王自己也在左.右手上各写一个整数.然后,让这 n 位大臣排成一排,国王 ...
- 【NOIP2012提高组】国王游戏 贪心 + 高精度
题目分析 题目答案不具有单调性,所以不可以二分,转而思考贪心.因为无法确定位置,所以考虑如何才能让对于每一个$1 ~ i$使得$i$的答案最大,即$1 ~ i$最后一个最优.若设对于位置$i$,$a[ ...
- luoguP1080 国王游戏 题解(NOIP2012)(贪心+高精)
luoguP1080 国王游戏 题目 #include<iostream> #include<cstdlib> #include<cstdio> #include& ...
- Luogu P1080国王游戏(贪心)
国王游戏 题目链接:国王游戏 ps:题目数据说明了要写高精度. 这个题的答案是\(a.l * a.r < b.l * b.r\)按照这个进行排序 题解中大部分只是如何证明排序是: \(a.l * ...
- 洛谷P1080(NOIP2012)国王游戏——贪心排序与高精度
题目:https://www.luogu.org/problemnew/show/P1080 排序方法的确定,只需任取两个人,通过比较与推导,可以得出ai*bi小的人排在前面: 高精度写的时候犯了些细 ...
- Luogu 1080 【NOIP2012】国王游戏 (贪心,高精度)
Luogu 1080 [NOIP2012]国王游戏 (贪心,高精度) Description 恰逢H国国庆,国王邀请n位大臣来玩一个有奖游戏.首先,他让每个大臣在左.右手上面分别写下一个整数,国王自己 ...
- 【NOIP 2012 国王游戏】 贪心+高精度
题目描述 恰逢 H 国国庆,国王邀请 n 位大臣来玩一个有奖游戏.首先,他让每个大臣在左.右 手上面分别写下一个整数,国王自己也在左.右手上各写一个整数.然后,让这 n 位大臣排 成一排,国王站在队伍 ...
随机推荐
- ubuntu修改Bash命令行提示符
用户通过远程登陆,初始的PS1为\s-\v\$, bash为/bin/bash,然后先后执行/etc/profile和~/.bash_profile中的命令. /etc/profile文件中调用执行/ ...
- request笔记记录
1.https请求报错解决方法,添加verify=False参数 r = requests.get(json=payload, headers=headers,verify=False) 1)由于这里 ...
- 【比特币】SPV是如何工作的
SPV是如何工作的 SPV, Bloom 过滤器和检查点 这是一篇技术文章,获取比特币的工作知识. 一个完整的节点,比如比特币核心,知道以下几点: 每一个当前正在围绕网络广播事务处理 每一个曾经被送到 ...
- MongoDB整库备份+整库导入
备份前检查: [root@Load29 tmp]# mongo localhost: MongoDB shell version: connecting to: localhost:/test Ser ...
- ubuntu 14.04 lamp 安装与配置
一.安装apache 1.打开终端:Ctrl+Alt+T sudo apt-get update 2.通过apt-get方式安装Apache: sudo apt-get install apache2 ...
- [UE4]Acotr
任何能被放在关卡中的对象都是Actor Tick是每帧都会调用的事件
- 用深度学习LSTM炒股:对冲基金案例分析
英伟达昨天一边发布“全球最大的GPU”,一边经历股价跳水20多美元,到今天发稿时间也没恢复过来.无数同学在后台问文摘菌,要不要抄一波底嘞? 今天用深度学习的序列模型预测股价已经取得了不错的效果,尤其是 ...
- 学习MongoDB 七: MongoDB索引(索引基本操作)(一)
一.简介 在MongoDB建立索引能提高查询效率,只需要扫描索引只存储的这个集合的一小部分,并只把这小部分加载到内存中,效率大大的提高,如果没有建立索引,在查询时,MongoDB必须执行全表扫描,在数 ...
- 使用CMQ和SCF实现邮件发送
准备腾讯云 API 调用工具 使用 API 命令行工具来管理和运行无服务器云函数(SCF),下面就先来安装配置该工具. 安装 Python 和 PIP Python 环境是腾讯云命令行工具运行时的必要 ...
- [Python] Scipy and Numpy(1)
import numpy as np #Create an array of 1*10^7 elements arr = np.arange(1e7) #Converting ndarray to l ...