Leetcode 1646. Get Maximum in Generated Array

文章作者:Tyan
博客:noahsnail.com  |  CSDN  | 

1. Description

Get Maximum in Generated Array

2. Solution

  • Version 1
class Solution:
    def getMaximumGenerated(self, n: int) -> int:
        if n == 0:
            return 0
        if n == 1:
            return 1
        maximum = 1
        nums = [0 for _ in range(n+1)]
        nums[1] = 1
        for k in range(2, n + 1):
            i = k // 2 
            if k % 2 == 0:
                nums[k] = nums[i]
            else:
                nums[k] = nums[i] + nums[i+1]
            maximum = max(maximum, nums[k])
        return maximum
  • Version 2
class Solution:
    def getMaximumGenerated(self, n: int) -> int:
        if n == 0:
            return 0
        if n == 1:
            return 1
        maximum = 1
        nums = [0, 1]
        for k in range(2, n + 1):
            i = k // 2 
            if k % 2 == 0:
                current = nums[i]
            else:
                current = nums[i] + nums[i+1]
            nums.append(current)
            maximum = max(maximum, nums[k])
        return maximum

Reference

  1. https://leetcode.com/problems/get-maximum-in-generated-array/

你可能感兴趣的:(Leetcode 1646. Get Maximum in Generated Array)