1646. 获取生成数组中的最大值

给你一个整数 n 。按下述规则生成一个长度为 n + 1 的数组 nums

  • nums[0] = 0
  • nums[1] = 1
  • 2 <= 2 * i <= n 时,nums[2 * i] = nums[i]
  • 2 <= 2 * i + 1 <= n 时,nums[2 * i + 1] = nums[i] + nums[i + 1]

返回生成数组 nums 中的 最大 值。

示例 1:

ini 复制代码
输入: n = 7
输出: 3
解释: 根据规则:
  nums[0] = 0
  nums[1] = 1
  nums[(1 * 2) = 2] = nums[1] = 1
  nums[(1 * 2) + 1 = 3] = nums[1] + nums[2] = 1 + 1 = 2
  nums[(2 * 2) = 4] = nums[2] = 1
  nums[(2 * 2) + 1 = 5] = nums[2] + nums[3] = 1 + 2 = 3
  nums[(3 * 2) = 6] = nums[3] = 2
  nums[(3 * 2) + 1 = 7] = nums[3] + nums[4] = 2 + 1 = 3
因此,nums = [0,1,1,2,1,3,2,3],最大值 3

示例 2:

ini 复制代码
输入: n = 2
输出: 1
解释: 根据规则,nums[0]、nums[1] 和 nums[2] 之中的最大值是 1

示例 3:

ini 复制代码
输入: n = 3
输出: 2
解释: 根据规则,nums[0]、nums[1]、nums[2] 和 nums[3] 之中的最大值是 2

题解:

js 复制代码
/**
 * @param {number} n
 * @return {number}
 */
// 当 i 为偶数,有 nums[i] = nums[i / 2];
// 当 i 为奇数时,有 nums[i] = nums[Math.floor(i / 2)] + nums[Math.floor(i / 2) + 1]
// 这两种情况可以合并为: i % 2 来判断奇偶数
// nums[i] = nums[Math.floor(i / 2)] + i % 2 * nums[Math.floor(i / 2) + 1]
var getMaximumGenerated = function (n) {
    if (n <= 1) return n
    const nums = new Array(n + 1).fill(0);
    nums[1] = 1;
    for (let i = 2; i <= n; ++i) {
        nums[i] = nums[Math.floor(i / 2)] + i % 2 * nums[Math.floor(i / 2) + 1]
    }
    return Math.max(...nums)
};
相关推荐
oioihoii4 分钟前
C++11标准库算法:深入理解std::none_of
java·c++·算法
karmueo463 小时前
视频序列和射频信号多模态融合算法Fusion-Vital解读
算法·音视频·多模态
写代码的小球5 小时前
求模运算符c
算法
大千AI助手9 小时前
DTW模版匹配:弹性对齐的时间序列相似度度量算法
人工智能·算法·机器学习·数据挖掘·模版匹配·dtw模版匹配
YuTaoShao10 小时前
【LeetCode 热题 100】48. 旋转图像——转置+水平翻转
java·算法·leetcode·职场和发展
生态遥感监测笔记11 小时前
GEE利用已有土地利用数据选取样本点并进行分类
人工智能·算法·机器学习·分类·数据挖掘
Tony沈哲11 小时前
macOS 上为 Compose Desktop 构建跨架构图像处理 dylib:OpenCV + libraw + libheif 实践指南
opencv·算法
刘海东刘海东12 小时前
结构型智能科技的关键可行性——信息型智能向结构型智能的转变(修改提纲)
人工智能·算法·机器学习
pumpkin8451412 小时前
Rust 调用 C 函数的 FFI
c语言·算法·rust