【寒假每日一题】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)二分查找只能针对有序的数组进行查询。

相关内容

热门资讯

工商银行取得数据同步方法专利 国家知识产权局信息显示,中国工商银行股份有限公司取得一项名为“数据同步方法、装置、计算机设备和存储介...
中央戏剧学院表演系主任王鑫,主... 据中央纪委国家监委驻教育部纪检监察组、河南省纪委监委2月13日消息:中央戏剧学院表演系主任王鑫涉嫌严...
于东来披露胖东来战略:永不上市... 2月12日晚间,继官宣年后退休后,胖东来创始人于东来在社交平台分享了胖东来的部分战略规划,称胖东来永...
2026年1月亲测:深圳短视频... 行业痛点分析 当前,短视频内容创作已进入工业化、精细化阶段,拍摄剪辑团队面临着一系列严峻的技术与运营...
原创 中... 近期国际汽车行业与中美贸易领域传来重磅消息,据路透社等多家外媒2月9日报道,中国汽车巨头比亚迪已经正...
节前债市偏暖支撑,30年国债E... 2026年2月13日早盘,截至09:51,30年国债ETF(511090)上涨0.14%。流动性方面...
央行今日将开展1万亿元买断式逆... 来源:证券时报网 证券时报记者 贺觉渊 中国人民银行2月12日发布公告称,将在13日以固定数量、利率...
纽约联储报告:美国消费者和企业... 当地时间2月12日,纽约联邦储备银行发布报告称,美国消费者和企业承担了特朗普政府加征关税的大部分成本...
美媒:美众议院通过决议,反对对... 据英国广播公司(BBC)2月12日报道,美国众议院以微弱优势通过一项决议,反对美国总统特朗普对加拿大...
于东来:胖东来永不上市 据大象新闻消息,2月12日晚,于东来在社交媒体发布胖东来的部分战略规划,称胖东来永远坚定学校的性质,...
持股过节,还是持币过节?A股春... 本文原标题《刚刚!券商,重磅发声!》 春节假期将至,A股也将迎来长达10天的休市期。到底是清仓持币,...
人均消费不到50元,小县城遍地... 蓝鲸新闻2月13日讯(记者 陆鹏鹏)腊月二十四南方小年,距离过年还有不到一周时间,乡镇的商业街上,量...
2026年贵金属开户哪家好?推... 在竞争激烈的金融交易领域,TopWealthTrading(TWT)作为一家以实体产业为根基的综合性...
多地春节前发文要求各大外卖平台... 多地春节前发文要求各大外卖平台停止“内卷式”竞争 春节前夕,全国多地市监部门发布春节外卖合规指引,...
2月13日国际晨讯 | 日韩股... 2月13日盘中,金银延续跌势;日韩股市2月13日低开;美股2月12日遭遇大规模抛售;OpenAI发布...
10000亿元!央行宣布,明日... 【导读】央行将开展10000亿元买断式逆回购操作 中国基金报记者 张玲 2月12日,央行发布消息称,...
原创 黄... 2026年2月6日,北京菜市口百货股份有限公司宣布次日起实施新的贵金属回购规则,将每日回购限额从20...
基金早班车丨纯债发行遇冷,“固... 一、交易提示 2026年以来,债券型基金发行整体遇冷,纯债基金新发数量寥寥,规模同比显著下滑。与之形...
全线大跌!超14万人爆仓 2月12日,券商中国微信发布最新消息:隔夜美股高开后,主要指数全线跳水,纳指盘中一度大跌近1%,以小...
于东来:胖东来永不上市,最高管... 2月12日晚,于东来在社交媒体发布胖东来的部分战略规划,称胖东来永远坚定学校的性质,所以“永不上市”...