笔试算法模拟题精解之“Codancer的数组封印”

简介: 我们逆向思考,对于给定的数组每次删去一个数,相邻两次操作的答案不会超过1。

【在线编程产品介绍】

阿里云开发者社区在线编程:

免费刷题大神器,助你拿到好offer

周赛月赛不停歇,做题还能领奖品

大赛笔试全真题,常做常新有惊喜

点击链接开始产品体验:https://developer.aliyun.com/coding

本文为大家介绍的是“122.Codancer的数组封印”的解法探究。先来看一下题目内容:

题目详情

等级:困难
知识点:DP、LIS
查看题目:Codancer的数组封印

Tom有一个长度为n的排列数组a,即a中的每个数字的范围都在[1,n]中并且每个数字都不重复。但是现在Codancer把整个数组给封印了!

现在Codancer给了Tom一个解封序列b,即bi代表第i次解封a[b[i]]。

接下来Tom每次都会解封一个位置的数字,令L[i]代表第i次解封后所有被解封的数字构成的数组的LIS的长度,现在Codancer想让Tom计算L[1]+L[2]+L[3]+…+L[n]的值是多少?

第一行是一个正整数n,代表a数组和b数组的长度,接下来第一行输入数组a,第二行输入数组b。(1<=n<=50000)

输出L[1]+L[2]+…+L[n]的值。

示例1
输入:
4
[4,2,1,3]
[1,2,4,3]
输出:
6
注意
L[1]=1 解封后为{4}
L[2]=1 解封后为{4,2}
L[3]=2 解封后为{4,2,3}
L[4]=2 解封后为{4,2,1,3}

解题方法:

第一步解封后数组为{4},因此L[1]=1
第二步解封后数组为{4,2},因此L[2]=1
第三步解封后数组为{4,2,3},因此L[3]=2
第四步解封后数组为{4,2,1,3},因此L[4]=2
因此L[1]+L[2]+L[3]+L[4]=6
image.png
红色数字构成的序列即为LIS。

我们逆向思考,对于给定的数组每次删去一个数,相邻两次操作的答案不会超过1,

对于第i次操作我们随便求一个LIS,如果第i+1次操作删除的数字在这个LIS内,

我们就要重新求LIS,否则答案保持不变,由于随机生成的全排列LIS长度的期望为sqrt(n),因此最多计算sqrt(n)次LIS。

时间复杂度:O(nsqrt(n)*log(n))

看完之后是不是有了答题思路了呢,快来练练手吧:122.Codancer的数组封印

在线编程周赛、月赛火热进行中,更有限时答题活动,定制卫衣、双肩背包、机械键盘等多重好礼等你来拿~每天都有好礼相送~点击了解周赛详情:在线编程3月份比赛正式开启!机械键盘等你拿!

b462f1d86b44481ca24c0ad63fe55948.png

相关文章
|
2月前
|
算法
Leetcode 初级算法 --- 数组篇
Leetcode 初级算法 --- 数组篇
41 0
|
2月前
|
算法 程序员 索引
数据结构与算法学习七:栈、数组模拟栈、单链表模拟栈、栈应用实例 实现 综合计算器
栈的基本概念、应用场景以及如何使用数组和单链表模拟栈,并展示了如何利用栈和中缀表达式实现一个综合计算器。
39 1
数据结构与算法学习七:栈、数组模拟栈、单链表模拟栈、栈应用实例 实现 综合计算器
|
2月前
|
存储 算法 定位技术
数据结构与算法学习二、稀疏数组与队列,数组模拟队列,模拟环形队列
这篇文章主要介绍了稀疏数组和队列的概念、应用实例以及如何使用数组模拟队列和环形队列的实现方法。
25 0
数据结构与算法学习二、稀疏数组与队列,数组模拟队列,模拟环形队列
|
4月前
|
存储 算法 Java
深入算法基础二分查找数组
文章深入学习了二分查找算法的基础,通过实战例子详细解释了算法的逻辑流程,强调了确定合法搜索边界的重要性,并提供了Java语言的代码实现。
深入算法基础二分查找数组
|
4月前
|
算法
【Azure Developer】完成算法第4版书中,第一节基础编码中的数组函数 histogrm()
【Azure Developer】完成算法第4版书中,第一节基础编码中的数组函数 histogrm()
|
4月前
|
算法
【算法】模拟算法——外观数组(medium)
【算法】模拟算法——外观数组(medium)
|
4月前
|
算法
【算法】前缀和——除自身以外数组的乘积
【算法】前缀和——除自身以外数组的乘积
|
8天前
|
算法
基于GA遗传算法的PID控制器参数优化matlab建模与仿真
本项目基于遗传算法(GA)优化PID控制器参数,通过空间状态方程构建控制对象,自定义GA的选择、交叉、变异过程,以提高PID控制性能。与使用通用GA工具箱相比,此方法更灵活、针对性强。MATLAB2022A环境下测试,展示了GA优化前后PID控制效果的显著差异。核心代码实现了遗传算法的迭代优化过程,最终通过适应度函数评估并选择了最优PID参数,显著提升了系统响应速度和稳定性。
|
5天前
|
算法
基于WOA鲸鱼优化的购售电收益与风险评估算法matlab仿真
本研究提出了一种基于鲸鱼优化算法(WOA)的购售电收益与风险评估算法。通过将售电公司购售电收益风险计算公式作为WOA的目标函数,经过迭代优化计算出最优购电策略。实验结果表明,在迭代次数超过10次后,风险价值收益优化值达到1715.1万元的最大值。WOA还确定了中长期市场、现货市场及可再生能源等不同市场的最优购电量,验证了算法的有效性。核心程序使用MATLAB2022a实现,通过多次迭代优化,实现了售电公司收益最大化和风险最小化的目标。
|
3天前
|
机器学习/深度学习 算法 数据安全/隐私保护
基于深度学习网络的宝石类型识别算法matlab仿真
本项目利用GoogLeNet深度学习网络进行宝石类型识别,实验包括收集多类宝石图像数据集并按7:1:2比例划分。使用Matlab2022a实现算法,提供含中文注释的完整代码及操作视频。GoogLeNet通过其独特的Inception模块,结合数据增强、学习率调整和正则化等优化手段,有效提升了宝石识别的准确性和效率。