[NOIP2012 提高组] 国王游戏(贪心,排序,高精度)

[NOIP2012 提高组] 国王游戏

题目描述

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

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

输入格式

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

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

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

输出格式

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

样例 #1

样例输入 #1

3 
1 1 
2 3 
7 4 
4 6

样例输出 #1

2

提示

【输入输出样例说明】

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

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

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

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

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

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

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

【数据范围】

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

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

对于 60 % 60\% 60% 的数据,有 1 ≤ n ≤ 100 1≤ n≤100 1n100

对于 60 % 60\% 60% 的数据,保证答案不超过 1 0 9 10^9 109

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

NOIP 2012 提高组 第一天 第二题

瞎贪心环节

  • 由于在队列最末端时,当前大臣前所有的大臣左手数的乘积一定是最大的,那么最后面的大臣右手的数要最小才能满足需求
  • 因此,我们可以得出一个正确性未定的贪心结论:将大臣右手数进行从小到大排序,这就是最优排序。

证明嘛我不会,贪心本身不就是半玄学

咳咳,总之,我们根据以上结论可以得出以下代码

#include<iostream>
#include<cstdio>
#include<cmath>
#include<algorithm>
#include<string.h>
using namespace std;
const int N=1e3+231;
int n,kl,kr;
long long int ans=0;
struct node{int le,ri;
}a[N];
bool cmp(node aa,node bb){return aa.ri<bb.ri;
}
int main(){
//	freopen("game.in","r",stdin);
//	freopen("game.out","w",stdout);cin>>n;cin>>kl>>kr;for(int i=1;i<=n;i++){cin>>a[i].le>>a[i].ri;}sort(a+1,a+1+n,cmp);int mul=kl;for(int i=1;i<=n;i++){//	ans=max(ans,mul/a[i].ri);if(ans<(mul/a[i].ri))ans=mul/a[i].ri;mul*=a[i].le;//cout<<ans<<" "<<mul<<endl;}cout<<ans<<endl;
//	fclose(stdin);
//	fclose(stdout);return 0;
}

非~~常简短,但是,这只能拿到50分。

由于a,b的大小过大,long long int会爆,我们需要高精度。(此贪心思路下高精度只能得到90分,若想真正AC,那需要另一个贪心思路)

如果第 i 个大臣放第 j 个大臣前面对答案的贡献小些,那么第 i 个大臣就放第 j 个大臣前面所以就是使 a [ i ] . x / a [ j ] . y < a [ j ] . x / a [ i ] . y a[i].x/a[j].y<a[j].x/a[i].y a[i].x/a[j].y<a[j].x/a[i].y
所以就是 a [ i ] . x ∗ a [ i ] . y < a [ j ] . x ∗ a [ j ] . y a[i].x∗a[i].y<a[j].x∗a[j].y a[i].xa[i].y<a[j].xa[j].y

#include<string.h>
#include<stdio.h>
#include<algorithm>
using namespace std;
struct node{int a,b;char cnta[10000],all[10000];//cnta 为前面所有a的乘积的逆序 all为乘积正序 char ca[100];//a转化为字符数组 char ans[10000];//所获得金币数 int lans;
}da[1001];
bool cmp(node a,node b){return a.a*a.b<b.a*b.b;
}
bool cmp2(node a,node b){//高精度比较 if(a.lans!=b.lans)return a.lans>b.lans;else{int i;for(i=0;i<a.lans;i++)if(a.ans[i]==b.ans[i]) {continue;}else return a.ans[i]>b.ans[i];}return 1==1;
}
void doit(int a,char b[]){//将数值转化成字符数组int lb=0;while(a>0){b[lb++]=a%10+'0';a/=10;}b[lb]='\0';
}
void add(char c[],char d[],int i){//错位相加 int lc=strlen(c),j;int jw = 0,tmp;for(j=0;j<lc;j++,i++){tmp=(d[i]>0?d[i]-'0':0)+c[j]-'0'+jw;d[i]=tmp%10+'0';jw=tmp/10;}if(jw){d[i++]=jw+'0';}d[i]='\0';
}
void gc(char a[],char b[],char d[]){//高乘 int la=strlen(a);int lb=strlen(b);int i,j;char c[10000];for(i=0;i<la;i++){int tmp;int jw = 0;int lc = 0;for(j=0;j<lb;j++){tmp = (a[i]-'0') * (b[j]-'0') + jw;c[lc++] = tmp % 10 + '0';jw = tmp / 10;}if(jw) c[lc++]=jw+'0';c[lc]='\0';add(c,d,i);}
}
void mult(char a[],int b, char c[]){int i = 0 , tag = 0 , la = strlen(a) , lc = 0;int d = 0;while(i<=la){if(b>d){d=d*10+a[i++]-'0';if(tag) c[lc++]='0';}else{c[lc++]=d/b+'0';d=d%b;d=d*10+a[i++]-'0';tag = 1;}}if(tag==0)c[lc++]='0';c[lc]='\0';
}
int main(){int n,i,j;memset(da,0,sizeof(da));scanf("%d",&n);scanf("%d%d",&da[0].a,&da[0].b);for(i=1;i<=n;i++){scanf("%d%d",&da[i].a,&da[i].b);}sort(da+1,da+n+1,cmp);doit(da[0].a,da[0].ca); da[0].cnta[0]='1';da[0].cnta[1]='\0';for(i=1;i<=n;i++){doit(da[i].a,da[i].ca);gc(da[i-1].cnta,da[i-1].ca,da[i].cnta);}for(i=1;i<=n;i++){//将乘积逆转 int k=0;for(j=strlen(da[i].cnta)-1;j>=0;j--)da[i].all[k++]=da[i].cnta[j];da[i].all[k]='\0';}for(i=1;i<=n;i++){mult(da[i].all,da[i].b,da[i].ans);da[i].lans = strlen(da[i].ans);}int ans = 1;for(i=2;i<=n;i++){if(!cmp2(da[ans],da[i]))ans=i;}printf("%s\n",da[ans].ans);return 0;
}

封面

请添加图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/146773.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

ssl证书 阿里的域名,腾讯云的证书

目录 1.腾讯云申请ssl免费证书 2.去阿里云进行解析 3.回到腾讯云 4.nginx的配置 说明&#xff1a;阿里云的免费证书用完了&#xff08;每年可以申请20个&#xff09;&#xff0c;还有个项目要用证书&#xff0c;第三方的证书免费的都是90天的。看了下腾讯云业可以申请免费的…

C++代码示例:排列数简单生成工具

文章目录 前言代码仓库内容代码&#xff08;有详细注释&#xff09;编译和运行命令结果总结参考资料作者的话 前言 C代码示例&#xff1a;排列数简单生成工具。 代码仓库 yezhening/Programming-examples: 编程实例 (github.com)Programming-examples: 编程实例 (gitee.com) …

数据集划分——train_test_split函数使用说明

当我们拿到数据集时&#xff0c;首先需要对数据集进行划分训练集和测试集&#xff0c;sklearn提供了相应的函数供我们使用 一、讲解 快速随机划分数据集&#xff0c;可自定义比例进行划分训练集和测试集 二、官网API 官网API sklearn.model_selection.train_test_split(*a…

Spring5 自定义标签开发

spring5 自定义脚本开发步骤 1 定义bean&#xff0c; public class User {private String id;private String userName;private String email;private String password;public String getId() {return id;}public void setId(String id) {this.id id;}public String getUser…

网络爬虫——urllib(2)

前言&#x1f36d; ❤️❤️❤️网络爬虫专栏更新中&#xff0c;各位大佬觉得写得不错&#xff0c;支持一下&#xff0c;感谢了&#xff01;❤️❤️❤️ Python网络爬虫_热爱编程的林兮的博客-CSDN博客 前篇讲解了urllib的基本使用、一个类型六个方法与下载相关内容&#xff0…

云原生Kubernetes:K8S配置资源管理

目录 一、理论 1.Secret 2.Secret创建 3.Secret使用 4.Configmap 5.Configmap创建 6.Configmap使用 二、实验 1.Secret创建 2.Secret使用 3.Configmap创建 4.Configmap使用 三、问题 1.变量引用生成资源报错 2.查看pod日志失败 3.创建configmap报错 4.YAML创建…

好看的货架效果(含3D效果)

搭配thymeleaf layui合成 货架一 1. css #gudinghuojia2F .layui-row { display: flex; justify-content: space-between; height: 100%;} #gudinghuojia2F .layui-col-xs10 {margin-right: 4%;} #gudinghuojia2F .layui-col-xs10:last-child {margin-right: 0;} .inner-ti…

Centos一键安装、切换各版本JDK

查看服务中的安装的jdk rpm -qa | grep java获取jdk各版本信息 yum -y list java*查看指定版本 yum -y list java*|grep 1.8安装jdk yum install java-11-openjdk当服务器中有多个版本jdk&#xff0c;切换指定jdk版本 alternatives --config java按照提示输入编号即可切换&…

2021-06-10 51单片机设计一个蜂鸣器报警电路每秒

缘由求助一下谢谢啦51单片机_嵌入式-CSDN问答设计一个蜂鸣器报警电路&#xff0c;按下K1&#xff0c;蜂鸣器响一声&#xff0c;按下K2&#xff0c;蜂鸣器响三声&#xff0c;按下K3,蜂鸣器长鸣。要求响声和间隔的时间均为1秒&#xff0c;长鸣不限时&#xff0c;但是此时应设置一…

验证曲线(validation_curve)项目实战

验证曲线 validation_curve 一、简介 validation_curve验证曲线&#xff0c;可确定不同参数值下的训练和测试分数 根据指定参数的不同值计算估计器的得分 这与使用一个参数的网格搜索类似。不过&#xff0c;这也会计算训练得分&#xff0c;只是一个用于绘制结果的工具。 二、…

【C++】unordered_set、unordered_map的介绍及使用

unordered_set、unordered_map的介绍及使用 一、unordered系列关联式容器二、unordered_map and unordered_multimap1、unordered_map的介绍2、unordered_map的使用&#xff08;1&#xff09;定义&#xff08;2&#xff09;接口使用 3、unordered_multimap 二、unordered_set a…

【python海洋专题八】Cartopy画地形水深图的contourf填充间隔数调整

【python海洋专题八】Cartopy画地形水深图的contourf填充间隔数调整 article 有时候想把contourf的画面变得更细 此时&#xff0c;就需要增加填充间隔数 本期内容 1&#xff1a;contourf的填充个数改变 cf ax.contourf(lon, lat, ele[:, :], levelsnp.linspace(-9000,0,60…

【中秋国庆不断更】HarmonyOS对通知类消息的管理与发布通知(下)

一、发布进度条类型通知 进度条通知也是常见的通知类型&#xff0c;主要应用于文件下载、事务处理进度显示。HarmonyOS提供了进度条模板&#xff0c;发布通知应用设置好进度条模板的属性值&#xff0c;如模板名、模板数据&#xff0c;通过通知子系统发送到通知栏显示。 目前系统…

JS三大运行时全面对比:Node.js vs Bun vs Deno

全文约 5100 字&#xff0c;预计阅读需要 15 分钟。 JavaScript 运行时是指执行 JavaScript 代码的环境。目前&#xff0c;JavaScript 生态中有三大运行时&#xff1a;Node.js、Bun、Deno。老牌运行时 Node.js 的霸主地位正受到 Deno 和 Bun 的挑战&#xff0c;下面就来看看这…

设计模式1、单例模式 Singleton

解释说明&#xff1a;确保一个类只有一个实例&#xff0c;并提供一个全局访问点来访问这个唯一实例 要点如下 有且仅有一个实例 必须自行创建自己的唯一实例 必须给所有其他对象提供这一实例 具体实现要点如下 提供一个 private 构造函数&#xff08;防止外部调用而构造类的实例…

【COMP304 LEC3】

LEC 3 1. Contingent Formulas&#xff1a; 定义&#xff1a;Truth or falsity of a propositional formula depends on the truth/falsity of the atoms in the formula 例子&#xff1a;p ∧ q is true if both p and q are true, false otherwise.这里p和q就是atoms&…

paddle2.3-基于联邦学习实现FedAVg算法-CNN

目录 1. 联邦学习介绍 2. 实验流程 3. 数据加载 4. 模型构建 5. 数据采样函数 6. 模型训练 1. 联邦学习介绍 联邦学习是一种分布式机器学习方法&#xff0c;中心节点为server&#xff08;服务器&#xff09;&#xff0c;各分支节点为本地的client&#xff08;设备&#…

【精品】Springboot 接收发送日期类型的数据

问题 无法请求到后台&#xff0c;后台报错&#xff1a;[Failed to convert property value of type java.lang.String to required type java.time.LocalDateTime for property &#xff1a; 2023-10-02T09:26:16.06908:00 WARN 14296 --- [p-nio-80-exec-1] .w.s.m.s.Defaul…

跨类型文本文件,反序列化与类型转换的思考

文章目录 应用场景序列化 - 对象替换原内容&#xff0c;方便使用编写程序取得结果数组 序列化 - JSON 应用场景 在编写热更新的时候&#xff0c;我发现了一个古早的 ini 文件&#xff0c;记录了许多有用的数据 由于使用的语言年份较新&#xff0c;没有办法较好地对 ini 文件的…

Canal实现数据同步

1、Canal实现数据同步 canal可以用来监控数据库数据的变化&#xff0c;从而获得新增数据&#xff0c;或者修改的数据。 1.1 Canal工作原理 原理相对比较简单&#xff1a; 1、canal模拟mysql slave的交互协议&#xff0c;伪装自己为mysql slave&#xff0c;向mysql master发送…