P1080 国王游戏
题意:
让n 位大臣排成一排,国王站在队伍的最前面。
排好队后,所有的大臣都会获得国王奖赏的若干金币,
每位大臣获得的金币数分别是:排在该大臣前面的所有人的左手上的数的乘积除以他自己右手上的数,然后向下取整得到的结果。
求一种排列顺序,使得得到金币最大的大臣得到的金币最少
输出最小值
先举个简单的锤子
n=2
有两种情况
左手 | 右手 | |
国王 | $a_0$ | $b_0$ |
大臣1 | $a_1$ | $b_1$ |
大臣2 | $a_2$ | $b_2$ |
可以计算得出$ans_1=max(\frac{a_0}{b_1},\frac{a_0*a_1}{b_2})$
左手 | 右手 | |
国王 | $a_0$ | $b_0$ |
大臣1 | $a_2$ | $b_2$ |
大臣2 | $a_1$ | $b_1$ |
可以计算得出$ans_2=max(\frac{a_0}{b_2},\frac{a_0*a_2}{b_1})$
对比两种情况的答案
$ans_1=max(\frac{a_0}{b_1},\frac{a_0*a_1}{b_2})$
$ans_2=max(\frac{a_0}{b_2},\frac{a_0*a_2}{b_1})$
分别设$k_1,k_2,k_3,k_4$ 对应代表上边的值
$ans_1=max(k_1,k_2)$
$ans_2=max(k_3,k_4)$
分母相同,分子大的大
因此
$k_2>k_3$
$k_4>k_1$
不妨设$ans_1<ans_2$
即$k_2<k_4$
也就是$\frac{a_0*a_1}{b_2}<\frac{a_0*a_2}{b_1}$
移个项,可得出
$a_1*b_1<a_2*b_2$
所以,当 $a_1*b_1<a_2*b_2$时,$ans_1<ans_2$
所以为了求出ans最小值
按l*r进行排序
注意要用高精!
#include<cstdio>
#include<iostream>
#include<cstring>
#include<cctype>
#include<algorithm>
using namespace std;
#define int long long
#define olinr return
#define _ 0
#define love_nmr 0
#define DB double
struct zhi_zhang_gao_jing_qu_si
{
int w[];
int len;
int &operator [] (int a)
{
return w[a];
}
zhi_zhang_gao_jing_qu_si()
{
memset(w,,sizeof w);
len=;
w[]=;
}
friend zhi_zhang_gao_jing_qu_si operator * (zhi_zhang_gao_jing_qu_si &a,int b)
{
zhi_zhang_gao_jing_qu_si t;
t.w[]=;
t.len=a.len+;
for(int i=;i<=t.len;i++)
{
t.w[i]+=a.w[i]*b;
t.w[i+]=t.w[i]/;
t.w[i]%=;
}
while(t.len>&&t.w[t.len]==) t.len--;
return t;
}
friend zhi_zhang_gao_jing_qu_si operator / (const zhi_zhang_gao_jing_qu_si &a,int b)
{
zhi_zhang_gao_jing_qu_si t;
t.len=a.len;
int x=;
for(int i=t.len;i>=;i--)
{
t.w[i]=(x*+a.w[i])/b;
x=(x*+a.w[i])%b;
}
while(t.len>&&t.w[t.len]==) t.len--;
return t;
}
friend bool operator < (const zhi_zhang_gao_jing_qu_si &a,const zhi_zhang_gao_jing_qu_si &b)
{
if(a.len>b.len) return false;
if(a.len<b.len) return true;
for(int i=a.len;i>=;i--)
{
if(a.w[i]<b.w[i]) return true;
if(a.w[i]>b.w[i]) return false;
}
return true;
}
void out()
{
for(int i=len;i>=;i--)
putchar(w[i]+'');
}
};
struct node
{
int l,r;
friend bool operator < (const node &a,const node &b)
{
return a.l*a.r<b.l*b.r;
}
}p[];
int n;
inline int read()
{
int x=,f=;
char ch=getchar();
while(!isdigit(ch))
{
if(ch=='-')
f=-f;
ch=getchar();
}
while(isdigit(ch))
{
x=(x<<)+(x<<)+(ch^);
ch=getchar();
}
return x*f;
}
signed main()
{
n=read();
n++;
for(int i=;i<=n;i++)
{
p[i].l=read();
p[i].r=read();
}
sort(p+,p+n+);
zhi_zhang_gao_jing_qu_si sm;
zhi_zhang_gao_jing_qu_si ans;
for(int i=;i<=n-;i++)
{
sm=sm*p[i].l;
ans=max(ans,sm/p[i+].r);
}
ans.out();
olinr ~~(^_^)+love_nmr;
}
P1080 国王游戏的更多相关文章
- 【题解】洛谷 P1080 国王游戏
目录 题目 思路 \(Code\) 题目 P1080 国王游戏 思路 贪心+高精度.按\(a \times b\)从小到大排序就可以了. \(Code\) #include<bits/stdc+ ...
- P1080 国王游戏 (等待高精度AC)
P1080 国王游戏 题解 贪心策略:按照大臣左右手数字乘积从小到大排序 假设我们已经把大臣排了一个顺序 假定在这个顺序下我们可以保证 得到奖赏最多的大臣所得奖赏最少 那么我们一旦交换任意两个大臣, ...
- 【流水调度问题】【邻项交换对比】【Johnson法则】洛谷P1080国王游戏/P1248加工生产调度/P2123皇后游戏/P1541爬山
前提说明,因为我比较菜,关于理论性的证明大部分是搬来其他大佬的,相应地方有注明. 我自己写的部分换颜色来便于区分. 邻项交换对比是求一定条件下的最优排序的思想(个人理解).这部分最近做了一些题,就一起 ...
- Luogu P1080国王游戏(贪心)
国王游戏 题目链接:国王游戏 ps:题目数据说明了要写高精度. 这个题的答案是\(a.l * a.r < b.l * b.r\)按照这个进行排序 题解中大部分只是如何证明排序是: \(a.l * ...
- [NOIP2012] 提高组 洛谷P1080 国王游戏
题目描述 恰逢 H 国国庆,国王邀请 n 位大臣来玩一个有奖游戏.首先,他让每个大臣在左.右 手上面分别写下一个整数,国王自己也在左.右手上各写一个整数.然后,让这 n 位大臣排 成一排,国王站在队伍 ...
- [贪心][高精]P1080 国王游戏(整合)
题目描述 恰逢 H 国国庆,国王邀请 n 位大臣来玩一个有奖游戏.首先,他让每个大臣在左.右手上面分别写下一个整数,国王自己也在左.右手上各写一个整数.然后,让这 n 位大臣排成一排,国王站在队伍的最 ...
- P1080 国王游戏 贪心 高精度
题目描述 恰逢 HH国国庆,国王邀请nn 位大臣来玩一个有奖游戏.首先,他让每个大臣在左.右手上面分别写下一个整数,国王自己也在左.右手上各写一个整数.然后,让这 nn 位大臣排成一排,国王站在队伍的 ...
- 洛谷 P1080 国王游戏
题目描述 恰逢 H 国国庆,国王邀请 n 位大臣来玩一个有奖游戏.首先,他让每个大臣在左.右手上面分别写下一个整数,国王自己也在左.右手上各写一个整数.然后,让这 n 位大臣排成一排,国王站在队伍的最 ...
- luogu P1080 国王游戏
题目描述 恰逢 H 国国庆,国王邀请 n 位大臣来玩一个有奖游戏.首先,他让每个大臣在左.右手上面分别写下一个整数,国王自己也在左.右手上各写一个整数.然后,让这 n 位大臣排成一排,国王站在队伍的最 ...
- 洛谷—— P1080 国王游戏
https://www.luogu.org/problem/show?pid=1080 题目描述 恰逢 H 国国庆,国王邀请 n 位大臣来玩一个有奖游戏.首先,他让每个大臣在左.右手上面分别写下一个整 ...
随机推荐
- java 多线程系列---JUC原子类(一)之框架
根据修改的数据类型,可以将JUC包中的原子操作类可以分为4类. 1. 基本类型: AtomicInteger, AtomicLong, AtomicBoolean ;2. 数组类型: AtomicIn ...
- 12-01JavaScript事件(Events)
JS事件 1.js事件通常和函数结合来使用,这样可以通过发生的事件来驱动函数的执行,从而引起html出现不同的效果. 2.属性(当这些事件的属性发生时,会触发function{}的函数): 1)ona ...
- namenode和datanode机制
转自:https://www.cnblogs.com/DarrenChan/p/6416043.html?utm_source=itdadao&utm_medium=referral 首先我们 ...
- C语言学习笔记--内存分区
1. 程序中的栈 1.1 栈的简介 (1)栈中现代计算机程序里最为重要的概念之一 (2)栈在程序中用于维护函数调用上下文 (3)函数中的参数和局部变量存储在栈上 (4)栈保存了一个函数调用所需的维护信 ...
- Codeforces #536 div2 E (1106E)Lunar New Year and Red Envelopes (DP)
题意:过年了,Bob要抢红包.抢红包的时间段为1 - n,有m个红包,每个红包有三个属性:st(红包出现的时间), ed(红包消失的时间),d(如果抢了这个红包,能够抢下一个红包的时间),w(红包的收 ...
- Guava Cache本地缓存
Guava介绍 Guava是一种基于开源的Java库,其中包含谷歌正在由他们很多项目使用的很多核心库. 这个库是为了方便编码,并减少编码错误. 这个库提供用于集合,缓存,支持原语,并发性,常见注解,字 ...
- essential C++中关于面向过程和面向对象的说明
昨天在阅读essential C++中看到了一个关于面向过程和面向对象的区别的例子,感觉挺好的.记录下来.... 这个例子是关于照相机的.照相机有三个性质,一个是控制位置:通常使用3个浮点数据来表示其 ...
- c# 新中新二代身份证阅读,包含头像,支持华视
需要用到dll和文件: 其中3个dll文件是需要调用的dll,license.dat文件为解压图片的授权文件 以下是需要用到的dll里面的方法: /************************端口 ...
- linux文件夹删除、创建
一.删除文件夹 rm -rf ./html2imag 二.创建文件夹 mkdir html2image
- 数据结构_yjjsj(伊姐姐数字游戏)
问题描述 伊姐姐热衷于各类数字游戏, 24 点. 2048.数独等轻轻松松毫无压力.一日,可爱的小姐姐邀请伊姐姐一起玩一种简单的数字 game,游戏规则如下:一开始桌上放着 n 张数字卡片,从左到右按 ...