news 2026/4/16 11:35:15

P13013 [GESP202506 五级] 奖品兑换

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
P13013 [GESP202506 五级] 奖品兑换

时间限制400ms

内存限制512.00M

难度普及/提高−

历史分数100

提交记录 查看题解 题目反馈

标签

GESP

题目背景

为了保证只有时间复杂度正确的代码能够通过本题,时限下降为 400 毫秒。

题目描述

班主任给上课专心听讲、认真完成作业的同学们分别发放了若干张课堂优秀券和作业优秀券。同学们可以使用这两种券找班主任兑换奖品。具体来说,可以使用 a 张课堂优秀券和 b 张作业优秀券兑换一份奖品,或者使用 b 张课堂优秀券和 a 张作业优秀券兑换一份奖品。

现在小 A 有 n 张课堂优秀券和 m 张作业优秀券,他最多能兑换多少份奖品呢?

输入格式

第一行,两个正整数 n,m,分别表示小 A 持有的课堂优秀券和作业优秀券的数量。

第二行,两个正整数 a,b,表示兑换一份奖品所需的两种券的数量。

输出格式

输出共一行,一个整数,表示最多能兑换的奖品份数。

输入输出样例

输入 #1复制

8 8 2 1

输出 #1复制

5

输入 #2复制

314159 2653589 27 1828

输出 #2复制

1599

说明/提示

对于 60% 的测试点,保证 1≤a,b≤100,1≤n,m≤500。

对于所有测试点,保证 1≤a,b≤104,1≤n,m≤109。

第一种做法暴力(得80分):

#include <bits/stdc++.h> using namespace std; #define int long long const int P=1e9+7; const int N=1e5+10; int n,m,a,b,ans; signed main(){ ios::sync_with_stdio(false); cin.tie(0); cout.tie(0); cin>>n>>m; cin>>a>>b; if(a<b) swap(a,b);//确保 a 较大 while(n>=a || m>=a){ if(n<m)swap(n,m); if(m<b)break; n-=a; m-=b; ans++;//从n,m中选择较大的变量减去较大的花费 } cout<<ans<<endl; return 0; }

第二种做法AC代码:

#include <bits/stdc++.h> #define int long long using namespace std; const int P=1e9+7; const int N=1e5+10; int n,m,a,b,ans; int s,d; signed main(){ cin>>n>>m; cin>>a>>b; if(a<b)swap(a,b); if(a==b){//进行特判 cout<<min(n,m)/a<<endl; return 0; } s=a+b,d=a-b; while(n>=a||m>=a){ if(n<m)swap(n,m); int x=(n-m)/d; if(x==0){//当n-m<d时 int y=m/s; ans+=y*2; n-=y*s,m-=y*s; x=2; } int v=min(n/a,min(m/b,x)); ans+=v,n-=v*a,m-=v*b; if(m<b) break;//不可进行兑换 } cout<<ans<<endl; return 0; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/3 5:27:55

PyArmor 混淆方法详解它到底“混”了什么,又是怎么“护”的?

1. PyArmor 在做的事&#xff1a;把“源码可读”变成“运行可用、理解困难” PyArmor 的核心思路是&#xff1a; 发布产物仍然是 .py&#xff0c;可以“无缝替换”原脚本&#xff08;大多数情况下&#xff09;(GitHub)但 .py 里不再是你的业务逻辑源码&#xff0c;而是一个引…

作者头像 李华
网站建设 2026/4/16 12:33:42

资源一号卫星参数详情

资源一号&#xff08;ZY-1&#xff09;卫星是中国和巴西合作研制的“资源”系列地球资源卫星中的第一代&#xff0c;也被称为中巴地球资源卫星&#xff08;CBERS&#xff09;。它开创了中国传输型对地观测卫星的新纪元。一、 卫星项目概况名称&#xff1a; 资源一号 / 中巴地球…

作者头像 李华
网站建设 2026/4/10 3:48:59

VideoSrt视频字幕生成工具:3大场景化解决方案彻底告别手动打字幕

VideoSrt视频字幕生成工具&#xff1a;3大场景化解决方案彻底告别手动打字幕 【免费下载链接】video-srt-windows 这是一个可以识别视频语音自动生成字幕SRT文件的开源 Windows-GUI 软件工具。 项目地址: https://gitcode.com/gh_mirrors/vi/video-srt-windows 你是否曾…

作者头像 李华
网站建设 2026/4/16 12:17:36

Velero API开发终极指南:从入门到精通

为什么选择Velero API&#xff1f; 【免费下载链接】velero Backup and migrate Kubernetes applications and their persistent volumes 项目地址: https://gitcode.com/GitHub_Trending/ve/velero 在当今云原生时代&#xff0c;Kubernetes已成为容器编排的事实标准。然…

作者头像 李华
网站建设 2026/4/16 11:00:55

Java线程安全:披萨争夺战的终极解法

哈哈&#xff0c;小白你好&#xff01;今天咱们来聊聊Java里的“线程安全”——这玩意儿就像一群程序员在办公室里抢同一份披萨&#xff0c;如果没点规矩&#xff0c;最后可能谁都吃不上完整的&#xff0c;还弄一地碎屑&#xff01;&#x1f604;简单说&#xff0c;线程安全就是…

作者头像 李华
网站建设 2026/4/16 10:44:25

Paperzz AI 期刊论文:从 “选题模糊” 到 “适配刊文框架”,学术新人如何高效搭建期刊级论文的写作路径

Paperzz-AI官网免费论文查重复率AIGC检测/开题报告/文献综述/论文初稿 paperzz - 期刊论文https://www.paperzz.cc/journalArticle 对学术新人而言&#xff0c;期刊论文写作的门槛远高于课程论文 —— 既要贴合期刊的 “选题方向”&#xff0c;又要符合 “摘要 - 引言 - 实证…

作者头像 李华