All Downloads are FREE. Search and download functionalities are using the official Maven repository.

g0001_0100.s0053_maximum_subarray.Solution.py Maven / Gradle / Ivy

# #Medium #Top_100_Liked_Questions #Top_Interview_Questions #Array #Dynamic_Programming
# #Divide_and_Conquer #Data_Structure_I_Day_1_Array #Dynamic_Programming_I_Day_5
# #Udemy_Famous_Algorithm #Big_O_Time_O(n)_Space_O(1)
# #2024_06_08_Time_501_ms_(83.84%)_Space_30.7_MB_(91.05%)

class Solution:
    def maxSubArray(self, nums: List[int]) -> int:
        maxi = float('-inf')
        sum_val = 0
        for num in nums:
            # calculating sub-array sum
            sum_val += num
            maxi = max(sum_val, maxi)
            if sum_val < 0:
                # there is no point to carry a -ve subarray sum. hence setting to 0
                sum_val = 0
        return maxi




© 2015 - 2025 Weber Informatics LLC | Privacy Policy