题目描述

恰逢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. Linux学习(二) --- 常用命令

    [TOC] 一.常用命令 1.目录 cd切换 cd 路径 切换到指定路径 cd .. 上一级 mkdir:创建目录 mkdir 目录名 pwd:查看 2.查看 ll命令:查询目录内容 ll 查看当前( ...

  2. NGDC|BIGD

    生命组学 生命起源经过复杂演化诞生了大量生物体及其基因组. 现今NCBI最大的基因组: 植物:糖松27.6G 动物:墨西哥蝾螈32.4G 大数据能做什么? 大数据时代如同大航海时代一样,需要具有与时代 ...

  3. tensorflow2使用中的一些问题

    from tensorflow import keras import tensorflow as tf import numpy as np print(tf.__name__,tf.__versi ...

  4. pip换源源

    介绍 """ 1.采用国内源,加速下载模块的速度 2.常用pip源: -- 豆瓣:https://pypi.douban.com/simple -- 阿里:https:/ ...

  5. Spring加载xml配置文件的方式

    梳理Spring的流程 xml是最常见的spring 应用系统配置源.Spring中的几种容器都支持使用xml装配bean,包括: XmlBeanFactory,ClassPathXmlApplica ...

  6. 爬取迷你mp4各个电影信息

    网站:www.minimp4.com # coding=utf-8 import requests from lxml import etree class Minimpe_moves(object) ...

  7. 研究NLP100篇必读的论文---已整理可直接下载

    100篇必读的NLP论文 100 Must-Read NLP 自己汇总的论文集,已更新 链接:https://pan.baidu.com/s/16k2s2HYfrKHLBS5lxZIkuw 提取码:x ...

  8. C# 元组

    Tuple<,); Console.WriteLine(t.Item1); Console.WriteLine(t.Item2); C#7 可以使用圆括号声明一个元组: (); Console. ...

  9. 002.前端开发知识,前端基础HTML(2020-01-07)

    一.列表标签 1.无序列表 ul <ul> <li>列表项1</li> <li>列表项2</li> <li>列表项3</l ...

  10. arduino basic issue

    1.    string char Str1[15]; char Str2[8] = {'a', 'r', 'd', 'u', 'i', 'n', 'o'}; char Str3[8] = {'a', ...