51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 2346|回复: 0
打印 上一主题 下一主题

做题记(4)P1080 国王游戏

[复制链接]
  • TA的每日心情
    无聊
    2024-7-12 13:16
  • 签到天数: 1 天

    连续签到: 1 天

    [LV.1]测试小兵

    跳转到指定楼层
    1#
    发表于 2019-2-1 15:02:41 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
    今天,做了洛谷上的P1080 国王游戏,题目如下:
    题目描述
    恰逢 H 国国庆,国王邀请 n 位大臣来玩一个有奖游戏。首先,他让每个大臣在左、右手上面分别写下一个整数,国王自己也在左、右手上各写一个整数。然后,让这 n nn 位大臣排成一排,国王站在队伍的最前面。排好队后,所有的大臣都会获得国王奖赏的若干金币,每位大臣获得的金币数分别是:排在该大臣前面的所有人的左手上的数的乘积除以他自己右手上的数,然后向下取整得到的结果。
    国王不希望某一个大臣获得特别多的奖赏,所以他想请你帮他重新安排一下队伍的顺序,使得获得奖赏最多的大臣,所获奖赏尽可能的少。注意,国王的位置始终在队伍的最前面。
    输入输出格式
    输入格式:
    第一行包含一个整数 n,表示大臣的人数。
    第二行包含两个整数a和 b,之间用一个空格隔开,分别表示国王左手和右手上的整数。
    接下来 $n $行,每行包含两个整数a 和 b,之间用一个空格隔开,分别表示每个大臣左手和右手上的整数。
    输出格式:
    一个整数,表示重新排列后的队伍中获奖赏最多的大臣所获得的金币数。
    作为一个蒟蒻,这道题把我难住了,想了半天脑子都要炸了 还想不出来。后来,我看了一下洛谷的题解,找到一点思路。根据题解中的证明,a×b乘积越小的大臣越应该排在前面。那么,这是为何?理由如下:

    左手        右手
    X1       
    Ai        Bi
    X2       
    Aj        Bj
    设从国王开始到第i位以前的乘积为X1,第i位左手为Ai,右手为Bi,第i位以后到第j位以前乘积为X2,第j位左手为Aj,右手为Bj,。
    由题意
    第i位的金币数为Mi=X1/Bi
    第j位的金币数为Mj=X1×Ai×X2/Bj
    因为金币数M1=max(Mi,Mj)
    所以M1=max(X1/Bi,X1×Ai×X2/Bj)
    现将i和j位置交换
    同理可得
    Mi=X1×Aj×X2/Bi
    Mj=X1/Bj
    M2=max(X1×Aj×X2/Bi,X1/Bj)
    当M2>M1时
    max(X1×Aj×X2/Bi,X1/Bj)>max(X1/Bi,X1×Ai×X2/Bj)
    因为X1×Aj×X2/Bi>X1/Bi,X1/Bj<X1×Ai×X2/Bj
    所以X1×Aj×X2/Bi>X1×Ai×X2/Bj
    化简得Aj×Bj>Ai×Bi;
    当M2<M1时
    max(X1×Aj×X2/Bi,X1/Bj)<max(X1/Bi,X1×Ai×X2/Bj)
    因为X1×Aj×X2/Bi>X1/Bi,X1/Bj<X1×Ai×X2/Bj
    所以X1×Aj×X2/Bi<X1×Ai×X2/Bj
    化简得Aj×Bj<Ai×Bi;
    所以a×b乘积越小越应该排在前面。

    但是,光这样做还是不行的,还要用高精度哦(巨坑)。
    ---------------------
    分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-9-28 11:22 , Processed in 0.064749 second(s), 24 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表