如何通过动态规划获取数组不相邻元素的最大和值
1、基于动态规划思想,实现算法,步骤如下:1. 创建一个数组 dp,其第 i 项代表包含参数数组 nums 第 i 剐疫柩缓项的所有不相邻元素的最大和值。并有公式: dp[i] = nums[i] + max( dp[i-2], dp[i-3] ) 注意:其中 i>=3。
2、编写本地测试主方法。
3、运行本地测试主方法,观察控制台输出,符合预期,本地测试通过。
4、平台提交算法,测试通过。
5、算法复杂度分析:算法需要遍历一遍参数数组,因此时间复杂度为 O(n),n即参数数组的长度;需要创建一个长度为 n 的数组辅助计算,因此空间复杂度也是 O(n)。
声明:本网站引用、摘录或转载内容仅供网站访问者交流或参考,不代表本站立场,如存在版权或非法内容,请联系站长删除,联系邮箱:site.kefu@qq.com。
阅读量:21
阅读量:80
阅读量:63
阅读量:51
阅读量:54