【寒假每日一题】AcWing 4656. 技能升级(难到飞起)
admin
2024-05-09 07:21:58
0

目录

一、题目

1、原题链接

2、题目描述

二、解题报告

1、思路分析

2、时间复杂度

3、代码详解 

三、知识风暴

1、贪心算法

2、归并算法

3、二分查找法


一、题目

1、原题链接

4656. 技能升级 - AcWing题库

2、题目描述

小蓝最近正在玩一款 RPG 游戏。

他的角色一共有 N 个可以加攻击力的技能。

其中第 i个技能首次升级可以提升 Ai点攻击力,以后每次升级增加的点数都会减少 Bi。

⌈Ai/Bi⌉(上取整)次之后,再升级该技能将不会改变攻击力。

现在小蓝可以总计升级 M 次技能,他可以任意选择升级的技能和次数。

请你计算小蓝最多可以提高多少点攻击力?

输入格式

输入第一行包含两个整数 N 和 M。

以下 N 行每行包含两个整数 Ai 和 Bi。

输出格式

输出一行包含一个整数表示答案。

数据范围

对于 40% 的评测用例,1≤N,M≤1000;
对于 60% 的评测用例,1≤N≤10^4,1≤M≤10^7;
对于所有评测用例,1≤N≤10^5,1≤M≤2×10^9,1≤Ai,Bi≤10^6。

输入样例:

3 6
10 5
9 2
8 1

输出样例:

47

二、解题报告

1、思路分析

原始思路

1)每次贪心选择提升攻击力最高的进行升级,即可以将每次可升级的攻击力存到一个multiset中,然后选择最后M项作为M次升级的方法,对后M项求和即为最多提升的攻击力。

2)该方法时间复杂度为O(n^2),所以必超时(十个测试数据过了四个),但并没有想出优化方法。

标准思路

思路来源:AcWing 4656. 技能升级(寒假每日一题2023) - AcWing

y总yyds

1)原始思路中因为我们每次都选择的是提升攻击力最多的,我们可以假设每个技能每次所能增加的攻击力是一个递减的等差数列,而我们每次都是选择最大的,也就是从这N个等差序列的头部进行选择,所以我们每次都是能够保证是从最初的技能开始一步步升级的,不会越级升级,因为针对某个技能在把它升到下一级之前,它一定是已经达到了下一级的前一个级别,因为我们每次都选择攻击力提升幅度最大的技能进行升级,而针对某个技能,它的攻击力提升是逐渐下降的,所以我们按照原贪心思路得到的解一定是正确的,下面我们需要对这个算法实现方法进行优化。

2)针对原始思路,我们需要求升序序列前M项的总和,我们直接暴力求肯定超时,我们可以在该 序列中找到某个数x前面正好存在M项,而这个x在该序列中可能存在多个,我们经过分析可知,这个x必定满足:在该序列中大于等于x的数的个数一定大于等于M个,而大于等于x+1的数的个数一定小于M个,而我们可以通过二分查找来查找x。

3)在找到x后,我们可以通过分析,将每个技能的每次升级的攻击力序列视为N个等差序列,根据等差序列的性质我们可知,假设其中某个等差序列首项为a0,公差为-d,则该序列中大于等于x的数的个数为𠃊(a-x)/b𠃎+1个((a-x)/b下取整+1个),所以我们之后也可以根据等差数列求和公式来计算每个序列大于等于x的数的代数和,最后用这个和减去和x相等的数的总和即为所求结果。

4)模拟上述过程,输出结果,即为所求。

2、时间复杂度

原始思路时间复杂度为O(n^2)

标准思路时间复杂度O(nlogn)

3、代码详解 

原始思路代码

#include 
#include 
using namespace std;
int A[1000100],B[1000100];
int main() {multisets;int N,M;cin>>N>>M;for(int i=0;i>A[i]>>B[i];for(int j=0;j

标准思路代码

#include 
using namespace std; 
int A[100010],B[100010];
int N,M;
//判断大于等于mid的数的个数是否有M个 
bool check(int mid){long long res=0;for(int i=0;i=mid){res+=(A[i]-mid)/B[i]+1;}}return res>=M;
} 
int main()
{  cin>>N>>M;for(int i=0;i>A[i]>>B[i];} int l=0,r=1e6;//二分从0开始,因为0可能为第M个数 while(l>1;//因为下一步l=mid,所以要上取整 if(check(mid)) l=mid;   //如果大于等于mid的数的个数有大于等于M个,则答案在[mid,1e6] else r=mid-1;}long long res=0,cnt=0;//cnt代表总项数 for(int i=0;i=r){int c=(A[i]-r)/B[i]+1;//每个序列中大于r(x)的项数int end=A[i]-(c-1)*B[i];cnt+=c;res+=(long long)(A[i]+end)*c/2;//每个等差数列中大于r(x)的总和}} cout<

三、知识风暴

1、贪心算法

贪心法用于解决最优化问题,这类问题有两种性质:

1)最优子结构:当一个问题的最优解包含其子问题的最优解时,称此问题具有最优子结构。

2)贪心选择性质:指问题的整体最优解可以通过一系列局部最优的选择,即贪心选择来得到。

2、归并算法

1归并也就是将两个或两个以上的有序文件合并成一个新的有序文件。

2)k路平衡归并是指文件已经有序,需要将k个归并段归并成一个有序段。

3、二分查找法

1)二分查找利用折半的思想,使每次查询都能排除一半的数字,提高了查询速度。

2)二分查找只能针对有序的数组进行查询。

相关内容

热门资讯

扬帆出海获佳绩!盐田区携手黄金... 2026年5月8日至10日 在马来西亚槟城举办的 “2026马来西亚黄金珠宝展销会”上 深圳市盐田区...
政策底与情绪顶:5月18日-2... 文/金透社 万捷 2026年5月第三周(5月11日-15日),A股市场走出了鲜明的分化格局。上证指数...
证监会重罚欺诈发行,广发证券被... 4.63亿元。 这是2026年5月,证监会对清越科技、元道通信两家公司欺诈发行、财务造假的罚款总额。...
国内存储厂长鑫科技更新招股书:... 去年12月底披露招股书后,5月17日,国内主要的DRAM(动态随机存取存储器)厂商长鑫科技更新了招股...
保伦股份IPO募资需求存疑:三... 作者|陈安 编辑|王以沫 5月13日晚间,上交所官网正式披露广东保伦电子股份有限公司(简称:保伦股份...
原创 特... 本文仅在今日头条发布,谢绝转载。近日,外交部发言人郭嘉昆在例行记者会上所作的表态,可谓教科书级的外交...
市场开始预期美联储将于年末年初... 来源:环球市场播报 本周通胀数据接连超出预期,投资者周五大幅押注:美联储可能在年底前转向加息模式。这...
潮玩经济升温 情绪消费带火非标... 图为消费者在王府中环泡泡玛特展览处“打卡”拍照。 □ 本报记者 王琦琛 5月15日,首届中国新文创市...
7年7任CEO,华林证券秦湘因... 日前,华林证券发布了一则重要的人事变动公告。据悉,华林证券董事会近日收到秦湘的书面辞职报告。秦湘因个...
原创 周... 近日,周鸿祎的一段演讲视频在网络上引发了广泛的关注和转发。他在台上谈起自己所在的互联网行业,语气中既...
风暴将至!华尔街大佬集体预警 这周末,全球市场都在热切讨论一件事——股债双杀。 周五,全球股市陷入集体暴跌,韩国股市一度触发熔断,...
内容发到手软,询盘不见起色?A... 01 前几天,我在郑州讲单仁牛商第245届《视播时代·企业全域营销快速增长系统》课程,我们也叫系统班...
广发银行全力打造服务粤港澳大湾... 建设粤港澳大湾区是国家重大区域发展战略。随着大湾区加快迈向国际一流湾区与世界级城市群,金融作为资源配...
北京抖音代运营代运营公司 1数字内容生产链中的专业化环节 在数字营销的生态中,存在一类专门负责内容平台账号系统性管理与内容...
2026年618有哪些值得关注... 先说一个容易被忽视的事实:618期间选返利平台,和日常选平台的标准完全不同。 日常购物,你关注的是返...
原创 今... 5月16日,国内黄金价格继续往下走,多家品牌金店的足金报价已经跌到1400元附近,比前一天低了十几元...
2026年华林电力专业配电柜批... 电力设备制造领域的品质标杆:深度解读一家专业企业的成长密码 配电柜如同电力系统的"神经中枢",其...
大调仓!伯克希尔开启后巴菲特时... 根据伯克希尔-哈撒韦公司15日向美国证券交易委员会提交的持仓文件,今年第一季度,公司对投资组合进行大...
原创 特... 图 | 美国总统特朗普 美国人突然发现了一个尴尬的现实,即中国不好啃,而欧洲却更像是一块摆在桌上的肥...
索罗斯基金一季度大举调仓!建仓... 日前,索罗斯基金(Soros Fund Management)向美国证券交易委员会(SEC)提交13...