题目描述

恰逢H国国庆,国王邀请n位大臣来玩一个有奖游戏。首先,他让每个大臣在左、右手上面分别写下一个整数,国王自己也在左、右手上各写一个整数。然后,让这n位大臣排成一排,国王站在队伍的最前面。排好队后,所有的大臣都会获得国王奖赏的若干金币,每位大臣获得的金币数分别是:排在该大臣前面的所有人的左手上的数的乘积除以他自己右手上的数,然后向下取整得到的结果。

国王不希望某一个大臣获得特别多的奖赏,所以他想请你帮他重新安排一下队伍的顺序,使得获得奖赏最多的大臣,所获奖赏尽可能的少。注意,国王的位置始终在队伍的最前面。

输入输出格式

输入格式

第一行包含一个整数n,表示大臣的人数。

第二行包含两个整数a和b,之间用一个空格隔开,分别表示国王左手和右手上的整数。

接下来n行,每行包含两个整数a和b,之间用一个空格隔开,分别表示每个大臣左手和右手上的整数。

输出格式

一个整数,表示重新排列后的队伍中获奖赏最多的大臣所获得的金币数。

样例

INPUT

3

1 1

2 3

7 4

4 6

OUTPUT

2

HINT

【输入输出样例说明】

按$ 1$、\(2\)、\(3\) 这样排列队伍,获得奖赏最多的大臣所获得金币数为 \(2\);

按 \(1\)、\(3\)、\(2\) 这样排列队伍,获得奖赏最多的大臣所获得金币数为$ 2$;

按 \(2\)、\(1\)、\(3\) 这样排列队伍,获得奖赏最多的大臣所获得金币数为 \(2\);

按$ 2$、\(3\)、$1 \(这样排列队伍,获得奖赏最多的大臣所获得金币数为\) 9$;

按 \(3\)、\(1\)、$2 $这样排列队伍,获得奖赏最多的大臣所获得金币数为 \(2\);

按$ 3$、\(2\)、\(1\) 这样排列队伍,获得奖赏最多的大臣所获得金币数为 \(9\)。

因此,奖赏最多的大臣最少获得 $2 $个金币,答案输出 \(2\)。

【数据范围】

对于 20%的数据,有 \(1≤ n≤ 10,0<a,b<8\);

对于 40%的数据,有$ 1≤ n≤ 20,0<a,b<8$;

对于 60%的数据,有 \(1≤ n≤ 100\);

对于 100%的数据,有 \(1 ≤ n ≤1,000,0<a,b<10000\)。

NOIP 2012 提高组 第一天 第二题

SOLUTION

贪心+排序

这题其实和奶牛吃花的那题非常相似。

我们在队伍中随意取相邻两个人进行分析。

由题意可知,这两个人排列的先后顺序对他们前面的人与他们后面的人的得到奖励的计算不会产生影响。

于是我们假定一人编号为\(i\),另一人为\(i+1\),因为前面的人左手的积和\(A,B\)的排列顺序无关,我们把其设为\(M\).

于是:

在保持原顺序与否的情况下得到:

\(i\)得到的最大奖励为:\(Max(\frac {M}{b_i},\frac {M\cdot a_{i+1}}{b_i})\);

\(i+1\)得到的最大奖励为:\(Max(\frac {M}{b_{i+1}},\frac {M\cdot a_i}{b_{i+1}})\);

把这四个式子同乘 \(\frac {b_i \cdot b_{i+1}}{M}\),得到

\(i\)的最大奖励为:\(Max(b_{i+1},a_{i+1}\cdot b_{i+1})\),即\(a_{i+1}\cdot b_{i+1}\)

\(i+1\)的最大奖励为:\(Max(b_i,a_{i}\cdot b_i)\),即\(a_i\cdot b_i\)

若\(a_{i+1}\cdot b_{i+1}> a_i\cdot b_i\)则说明在交换的情况下得到的最大值会比交换前的大,不能进行交换,所以当\(i,i+1\)满足\(a_i\cdot b_i<a_{i+1}\cdot b_{i+1}\)时,不必交换顺序。

从lyd书上抄的一段然后我们能够根据冒泡排序的知识,有:任何一个序列都能通过邻项交换的方式变为有序序列。故当逆序对数为0,即按上面规律排序时就是最优策略。

接着记得写好高精就行qwq

这题我一个不熟悉重载的人用重载写高精,调的时间比我推式子的时间还长qwq。

#include <iostream>
#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <algorithm>
using namespace std;
typedef long long LL;
inline int read(){
int x=0,f=1;char ch=getchar();
while (ch<'0'||ch>'9') {if (ch=='-') f=-1;ch=getchar();}
while (ch>='0'&&ch<='9') {x=x*10+ch-48;ch=getchar();}
return x*f;}
const int NUM=1000,N=101000;
const int M=10000;
struct Bignumber{
int len,b[NUM];
Bignumber(){len=0;memset(b,0,sizeof(b));}
inline void clear(){len=0;memset(b,0,sizeof(b));}
Bignumber(int x){memset(b,0,sizeof(b));len=0;if (x==0) {len=1;return;}
while (x) {b[++len]=x%M;x/=M;}}
inline void print(){
printf("%d",b[len]);
for (int i=len-1;i>=1;--i) printf("%04d",b[i]);puts("");}
inline Bignumber operator *(const int &a)const{
Bignumber c;c.clear();c.len=len+5;
for (int i=1;i<=len;++i){
c.b[i]+=b[i]*a;c.b[i+1]=c.b[i]/M;c.b[i]%=M;}
while (!c.b[c.len]&&c.len>1) c.len--;
return c;
}
inline Bignumber operator /(const int &a)const{
Bignumber c;c.clear();c.len=len;int rst=0;
for (int i=len;i>=1;--i){
rst=rst*M+b[i];c.b[i]=rst/a;rst%=a;}
while (!c.b[c.len]&&c.len>1) --c.len;
return c;}
};
inline Bignumber Max(Bignumber a,Bignumber b){
if (a.len>b.len) return a;
if (b.len>a.len) return b;
for (int i=a.len;i>=1;--i){
if (a.b[i]==b.b[i]) continue;
if (a.b[i]>b.b[i]) return a;else return b;}
return a;}
struct MNST{int l,r;}mst[N];
bool cmp(MNST a,MNST b){return ((a.l*a.r)<(b.l*b.r));}
int n;
int main(){
int i,j;
n=read();
Bignumber mlt;mlt.clear();mlt.len=1;
int l0=read(),r0=read();
mlt.b[1]=l0;
for (i=1;i<=n;++i) {mst[i].l=read();mst[i].r=read();}
sort(mst+1,mst+1+n,cmp);
Bignumber ans;ans.clear();ans.len=1;
for (i=1;i<=n;++i){
if (mst[i].l==0) break;
Bignumber rec=mlt/mst[i].r;mlt=mlt*mst[i].l;
ans=Max(ans,rec);
}
ans.print();
return 0;
}

Luogu_1080_国王游戏的更多相关文章

  1. NOIP2012 国王游戏

    2国王游戏 (game.cpp/c/pas) [问题描述] 恰逢 H 国国庆,国王邀请 n 位大臣来玩一个有奖游戏.首先,他让每个大臣在左.右手上面分别写下一个整数,国王自己也在左.右手上各写一个整数 ...

  2. 【NOIP 2012 国王游戏】 贪心+高精度

    题目描述 恰逢 H 国国庆,国王邀请 n 位大臣来玩一个有奖游戏.首先,他让每个大臣在左.右 手上面分别写下一个整数,国王自己也在左.右手上各写一个整数.然后,让这 n 位大臣排 成一排,国王站在队伍 ...

  3. Codevs 1198 国王游戏 2012年NOIP全国联赛提高组

    1198 国王游戏 2012年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description 恰逢 H 国国庆,国王邀 ...

  4. Luogu 1080 【NOIP2012】国王游戏 (贪心,高精度)

    Luogu 1080 [NOIP2012]国王游戏 (贪心,高精度) Description 恰逢H国国庆,国王邀请n位大臣来玩一个有奖游戏.首先,他让每个大臣在左.右手上面分别写下一个整数,国王自己 ...

  5. NOIP国王游戏

    #include<iostream> #include<cstdio> #include<cstdlib> #include<cstring> #inc ...

  6. AC日记——国王游戏 洛谷 P1080

    国王游戏 思路: 贪心+高精: 代码: #include <bits/stdc++.h> using namespace std; #define maxn 1005 struct Dat ...

  7. Luogu P1080国王游戏(贪心)

    国王游戏 题目链接:国王游戏 ps:题目数据说明了要写高精度. 这个题的答案是\(a.l * a.r < b.l * b.r\)按照这个进行排序 题解中大部分只是如何证明排序是: \(a.l * ...

  8. 国王游戏 2012年NOIP全国联赛提高组(贪心+高精)

    P1080 国王游戏 题目描述 恰逢 H 国国庆,国王邀请 n 位大臣来玩一个有奖游戏.首先,他让每个大臣在左.右手上面分别写下一个整数,国王自己也在左.右手上各写一个整数.然后,让这 n 位大臣排成 ...

  9. 【题解】洛谷 P1080 国王游戏

    目录 题目 思路 \(Code\) 题目 P1080 国王游戏 思路 贪心+高精度.按\(a \times b\)从小到大排序就可以了. \(Code\) #include<bits/stdc+ ...

随机推荐

  1. Java多线程求和

    package test; import java.util.concurrent.*; import java.util.concurrent.locks.Lock; import java.uti ...

  2. python全局灰度线性变换——自由设定图像灰度范围

    全局线性变换的公式是s = (r-a)*(d-c)/(b-a)+c,其中a.b是原图片的灰度最小值和最大值,c.d是变换后的灰度值的最小值和最大值.r是当前像素点的灰度值,s是当前像素点变换后的灰度值 ...

  3. java生成图形验证码

    效果图 import java.awt.Color; import java.awt.Font; import java.awt.Graphics; import java.awt.image.Buf ...

  4. OpenCV On Android环境配置最新&最全指南(Eclipse篇)

    简介 本教程是经过本人多次踩坑,并参考网上众多OpenCV On Android的配置教程总结而来,尽希望能帮助学习移动图像处理的朋友们少走弯路.这也是本人第一次在简书上发布文章,如有不足,希望各位d ...

  5. 基于JWT的Token认证机制及安全问题

    [干货分享]基于JWT的Token认证机制及安全问题 https://bbs.huaweicloud.com/blogs/06607ea7b53211e7b8317ca23e93a891

  6. RDD(九)——序列化问题

    在实际开发中我们往往需要自己定义一些对于RDD的操作,那么此时需要考虑的主要问题是,初始化工作是在Driver端进行的,而实际运行程序是在Executor端进行的,这就涉及到了跨进程通信,是需要序列化 ...

  7. Codeforces 1293A - ConneR and the A.R.C. Markland-N

    题目大意: ConneR老师想吃东西,他现在在大楼的第s层,大楼总共有n层,但是其中有k层的餐厅关门了. 然后给了这k层关门的餐厅分别所在的楼层. 所以问ConneR老师最少得往上(或者往下)走几层楼 ...

  8. liquibase使用教程

    在项目中引入liquibase过程: 1.父项目 pom.xml 中添加依赖 <dependencies> <dependency> <groupId>mysql& ...

  9. 大言不惭 swank? talk about sth or speak too confidently

    cán,意思是指说大话而毫不感到难为情.出自<论语·宪问>:“子曰:‘其言之不怍,则为之也难.’”宋·朱熹注:“大言不惭,则无必为之志,而不自度其能否也.欲践其言,其不难哉!” 是不是类似 ...

  10. 学习4412开发板gdb和gdbserver的调试

    因为有很多的小伙伴是从单片机转过来的,用惯了单片机上的JLINK调试程序,换到Linux上非常的不习惯.确实,如果能设置断点,单步调试,查看变量,那确实是太爽了,那么在我们的Linux可以做到吗,答案 ...