Skip to content
LC-1269 Hard LeetCode

1269. Number of Ways to Stay in the Same Place After Some Steps

Read the full problem statement on LeetCode.
Difficulty: hard Acceptance: 50% Topics: Dynamic Programming
View full problem on LeetCode
Reference solution (spoiler · python)
# Time:  O(n^2), n is the number of steps
# Space: O(n)
    
class Solution(object):
    def numWays(self, steps, arrLen):
        """
        :type steps: int
        :type arrLen: int
        :rtype: int
        """
        MOD = int(1e9+7)
        l = min(1+steps//2, arrLen)
        dp = [0]*(l+2)
        dp[1] = 1
        while steps > 0:
            steps -= 1
            new_dp = [0]*(l+2)
            for i in xrange(1, l+1):
                new_dp[i] = (dp[i] + dp[i-1] + dp[i+1]) % MOD
            dp = new_dp
        return dp[1]

Solution from kamyu104/LeetCode-Solutions · MIT