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 位大臣排 成一排,国王站在队伍 ... 
随机推荐
- 敏感词文本文件 filtered_words.txt,里面的内容为以下内容,当用户输入敏感词语时,则打印出 Freedom,否则打印出 Human Rights
			敏感词文件内容: 代码: def filtered_words(path='filtered_words.txt'): words = [] with open(path, 'r', encoding ... 
- jquery ztree异步搜索
			一.初始异步加载树 初始化默认给出一个根结点,再结合异步加载的方式手动触发默认加载第一层,如图: 代码如下: var treeSetting = { async: { enable: true, ur ... 
- Java堆外内存之四:直接使用Unsafe类操作堆外内存
			在nio以前,是没有光明正大的做法的,有一个work around的办法是直接访问Unsafe类.如果你使用Eclipse,默认是不允许访问sun.misc下面的类的,你需要稍微修改一下,给Type ... 
- 【整理总结】代码沉淀 - CefSharp - 比较流行的第三方内嵌浏览器组件
			.NET (WPF and Windows Forms) bindings for the Chromium Embedded Framework web: https://github.com/ce ... 
- 错误:Unsupported major.minor version 51.0(jdk版本错误)
			Java.lang.UnsupportedClassVersionError: org/apache/nutch/crawl/Crawl3 : Unsupported major.minor vers ... 
- Git 查询某次历史提交的修改内容
			在工作时,有时候想查看某次的提交修改了哪些的内容. 我们首先可以git log显示历史的提交列表: 之后我们用git show <commit-hashId> 便可以显示某次提交的修改内容 ... 
- Java 运算符-=,+=混合计算详解
			+=与-=运算符混合计算解析: int x = 3; x += x -= x -= x += x -= x; 详解:算数运算按运算符优先级运算,从右至左计算. 1. x=x-x; 实际为 3 - 3 ... 
- (转)android系统开发 AP 和 BP 简要说明
			手机的AP和BP根据上下文可以指代硬件和软件两种意思. 1) 大多数的手机都含有两个处理器.操作系统.用户界面和应用程序都在Application Processor(AP)上执行,AP一般采用AR ... 
- C# 控制台程序(Console Application )启动后隐藏
			背景 前段时间给项目编写了数据适配器,读取其他系统的数据后推送到MQ上,我们的系统通过订阅MQ的方式来获取.由于其他系统支持C#编程,且为了一时方便,选择了C#的控制台程序. 最近用户在使用中,总是不 ... 
- Maven   插件管理
			偶然与巧合 舞动了蝶翼 谁的心头风起 前赴而后继 万千人追寻 荒漠唯一菩提 似擦身相遇 或擦肩而去 命运犹如险棋 无数时间线 无数可能性 终于交织向你 
