题目:https://www.luogu.org/problemnew/show/P1080

排序方法的确定,只需任取两个人,通过比较与推导,可以得出ai*bi小的人排在前面;

高精度写的时候犯了些细节错误,详见注释。

代码如下:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define MAXN 200005
using namespace std;
typedef long long ll;//用long long!
ll n,ka,kb,ans[MAXN],tmp[MAXN],tmp2[MAXN],c[MAXN];
struct N{
ll a,b;
}p[];
bool cmp(N x,N y)
{
return x.a*x.b<y.a*y.b;
}
void chu(ll a[],ll b)
{
ll x=;
c[]=a[];
for(ll i=a[];i>;i--)//倒序存储,正序除
{
c[i]=(x*+a[i])/b;
x=(x*+a[i])%b;
}
while(c[c[]]==&&c[]>)c[]--;
}
void ch(ll a[],ll b)
{
ll x=;
for(ll i=;i<=a[];i++)//倒序乘
{
a[i]*=b;a[i]+=x;
x=a[i]/;
a[i]%=;
}
while(x)a[]++,a[a[]]=x%,x/=;
}
int com(ll a[],ll b[])
{
if(a[]>b[])return ;
if(a[]<b[])return -;
for(ll i=a[];i;i--)//倒序!
if(a[i]>b[i])return ;
return ;
}
void print(ll a[])
{
// if(a[a[0]]==0)//?
// {
// printf("1");
// return;
// }
printf("%lld",a[a[]]);
for(ll i=a[]-;i>;i--)
{
printf("%lld",a[i]/);
a[i]%=;
printf("%lld",a[i]/);
a[i]%=;
printf("%lld",a[i]/);
a[i]%=;
printf("%lld",a[i]);
}
}
int main()
{
scanf("%lld%lld%lld",&n,&ka,&kb);
for(ll i=;i<=n;i++)
scanf("%d%d",&p[i].a,&p[i].b);
sort(p+,p+n+,cmp);
tmp[]=;tmp[]=ka;//压位
for(ll i=;i<=n;i++)
{
memcpy(tmp2,tmp,sizeof tmp);
memset(c,,sizeof c);
chu(tmp2,p[i].b);
if(com(c,ans)>)memcpy(ans,c,sizeof c);//必须>0,否则-1也会被算!
ch(tmp,p[i].a);
}
print(ans);
return ;
}

这个运行起来有点慢,有些地方写得不够好,下面有一篇运行很快的代码,可以比较看看提速的方法。

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
using namespace std;
const int INF=;
typedef long long ll;
ll n,gb,ljc[],max,tmp[],ans[];
char tp[];
struct Node{
ll a,b,w;
}r[];
bool cmp(Node x,Node y)
{
return x.w<y.w;
}
void chu(ll b)
{
ll x=;
tmp[]=ljc[];
for(ll i=ljc[];i;i--)
{
ll s=ljc[i]+x*INF;
tmp[i]=s/b;
x=s%b;
}
while(!tmp[tmp[]]&&tmp[]>)tmp[]--;
}
bool comp(ll ans[],ll b[])
{
if(ans[]>b[])return ;
if(ans[]<b[])return ;
for(ll i=ans[];i;i--)
{
if(ans[i]>b[i])return ;
if(ans[i]<b[i])return ;
}
return ;
}
void mul(ll a)
{
ll x=;
for(ll i=;i<=ljc[];i++)
{
ll s=ljc[i]*a+x;
x=s/INF;
ljc[i]=s%INF;
}
if(x)ljc[]++,ljc[ljc[]]=x;//至多进一位
}
int main()
{
scanf("%lld%lld%lld",&n,&ljc[],&gb);
ljc[]=;
for(ll i=;i<=n;i++)
{
scanf("%lld%lld",&r[i].a,&r[i].b);
r[i].w=r[i].a*r[i].b;
}
sort(r+,r+n+,cmp);
for(ll i=;i<=n;i++)
{
memset(tmp,,sizeof tmp);
chu(r[i].b);
if(comp(ans,tmp))memcpy(ans,tmp,sizeof tmp);
mul(r[i].a);
}
printf("%lld",ans[ans[]]);
for(ll i=ans[]-;i;i--)
{
printf("%lld",ans[i]/);
printf("%lld",ans[i]/%);
printf("%lld",ans[i]/%);
printf("%lld",ans[i]%);
}
return ;
}

洛谷P1080(NOIP2012)国王游戏——贪心排序与高精度的更多相关文章

  1. 【题解】洛谷P1080 [NOIP2012TG] 国王游戏(贪心+高精度)

    次元传送门::洛谷P1080 思路 我们模拟一下只有两个大臣的时候发现 当a1​∗b1​<a2​∗b2​是ans1<ans2 所以我们对所有大臣关于左右手之积进行排序 得到最多钱的大臣就是 ...

  2. 【洛谷P1080】国王游戏

    我们按照左右手数的乘积升序排序,就能使最多金币数最小了 为什么呢? 我们知道: 1)如果相邻的两个人交换位置,只会影响到这两个人的值,不会影响他人 2)假设相邻的两个人i, i + 1.设A[i] B ...

  3. 洛谷P1080 [NOIP2012提高组D1T2]国王游戏 [2017年5月计划 清北学堂51精英班Day1]

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

  4. [noip2012]国王游戏<贪心+高精度>

    题目链接: https://vijos.org/p/1779 https://www.luogu.org/problem/show?pid=1080 http://codevs.cn/problem/ ...

  5. [NOIp2012] 国王游戏(排序 + 贪心 + 高精度)

    题意 给你两个长为 \(n+1\) 的数组 \(a,b\) ,你需要定义一个顺序 \(p\) (\(p_0\) 永远为 \(0\)) 能够最小化 \[ \max_{i=1}^{n} \frac{\pr ...

  6. 洛谷$P$2123 皇后游戏 贪心

    正解:贪心 解题报告: 传送门! 心血来潮打算把$luogu$提高历练地及其之前的所有专题都打通关,,,$so$可能会写一些比较水的题目的题解$QAQ$ 这种题,显然就套路地考虑交换相邻两个人的次序的 ...

  7. Luogu P1080 [NOIP2012]国王游戏

    题目 按\(a_i*b_i\)升序排序即可. 证明考虑交换法. 对于排序后相邻的两个人\(i,j(a_ib_i\le a_jb_j)\),设前面的总的积为\(s\),则当前答案为\(\max(\fra ...

  8. NOIP2012 Day1 T2国王游戏 洛谷P1080

    第一篇博客啊…… 由于我太弱了,还要去补不全的知识点准备参加人生第一次NOIp,所以第一篇博客就简短一点好了(偷懒就直说吧……) 洛谷P1080传送门 题意概括: 有N对数ai和bi,以及两个数a0和 ...

  9. 洛谷1377 M国王 (SCOI2005互不侵犯King)

    洛谷1377 M国王 (SCOI2005互不侵犯King) 本题地址:http://www.luogu.org/problem/show?pid=1377 题目描述 天天都是n皇后,多么无聊啊.我们来 ...

随机推荐

  1. ui-router $transitions 用法

    1. //route redirection $transitions.onStart({to: 'manage'}, function (trans) { var params = trans.pa ...

  2. python学习(三)数字类型示例

    奶奶的报了这个错,我以为可以像java中字符串加数字的嘛 Traceback (most recent call last):   File "./number.py", line ...

  3. Linux下Kafka单机安装配置方法

    Kafka是一个分布式的.可分区的.可复制的消息系统.它提供了普通消息系统的功能,但具有自己独特的设计.这个独特的设计是什么样的呢? 首先让我们看几个基本的消息系统术语: •Kafka将消息以topi ...

  4. 数据库ACID操作---事务四原则

    事务操作四原则: 1>原子性:简单来说——整个事务操作如同原子已经是物理上最小的单位,不可分离事务操作要么一起成功,要么一起失败. 2>一致性:倘若事务操作失败,则回滚事务时,与原始状态一 ...

  5. MyBatis缓存介绍

    一.MyBatis缓存介绍 正如大多数持久层框架一样,MyBatis 相同提供了一级缓存和二级缓存的支持 一级缓存: 基于PerpetualCache 的 HashMap本地缓存.其存储作用域为 Se ...

  6. Python中类方法、__new__方法和__init__方法解析

    在编程语言中创建一个类,有构造方法这样的一个术语.而在Python中,通常大家都认为__init__是构造方法,其实并不完全等同.在构建类中,有一个特殊的方法__new__,这个才能等同为构造方法. ...

  7. EasyPlayerPro windows播放器之多窗口播放音量控制方法

    EasyPlayerPro-win基础版本的音频播放为单一通道播放,即同一时间仅允许一个通道播放声音,现应客户需求,在基础版本上实现独立的音频播放,即每个通道可同时播放视频和音频; 设计思路 将音频播 ...

  8. Dijkstra的堆优化

    先附上一个例题:P3371 [模板]单源最短路径 一眼扫去,最短路... spfa可行,但是今天的主题是Dijkstra: #include<iostream> #include<a ...

  9. OSGI简介(转)

    原文地址 目前,业内关于OSGI技术的学习资源或者技术文档还是很少的.我在某宝网搜索了一下“OSGI”的书籍,结果倒是有,但是种类少的可怜,而且几乎没有人购买.因为工作的原因我需要学习OSGI,所以我 ...

  10. P3715 [BJOI2017]魔法咒语

    P3715 [BJOI2017]魔法咒语 用基本词汇组成\(L\)长度的单词,其中不能包含禁忌词汇 用禁忌词汇建强大的\(tire\)图 解决: 分类讨论,\(L<=100\)用普通dp暴力在\ ...