zoukankan      html  css  js  c++  java
  • The Day Two 找到一个具有最大和的连续子数组,返回其最大和

    """
    给定一个整数数组 nums ,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。
    
    示例:
    
    输入: [-2,1,-3,4,-1,2,1,-5,4],
    输出: 6
    解释: 连续子数组 [4,-1,2,1] 的和最大,为 6。
    
    来源:力扣(LeetCode)
    链接:https://leetcode-cn.com/problems/maximum-subarray
    著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
    """
    """
    author:jiyanjiao
    date :2019-10-22
    """
    
    
    class Solution:
        max_index = 0   # 子数组和最大的索引
        max_sum = 0     # 子数组和的最大值
        sum_list = []   # 子数组和的列表
        sub_list = []   # 最大和的子数组列表
    
        def maxSubArray(self, nums_list, le) -> int:
            """
            :param nums_list: 传入的数组
            :param le: 期望的子数组的长度
            :return: 子数组和最大值,最大和的子数组的列表
            """
            if le > len(nums_list):
                raise Exception('子数组长度大于父数组长度')
            elif le < 1 or len(nums_list) == 0:
                raise Exception("父数组不能为空,或者,子数组至少包含一个元素")
            elif le == len(nums_list):
                raise Exception("仅有一组数不符合规则")
            
            # 求指定长度子数组的和
            for i in range(len(nums_list)-1):
                s_sum = 0
                for j in range(i, i+le):
                    # 子数组顺序的组合情况,去掉最后一组不够长度的子数组
                    if len(nums_list) % le == 0:
                        s_sum += nums_list[j]
                    else:
                        s_sum += nums_list[j-1]
                    i += 1
                self.sum_list.append(s_sum)
            
            # 求子数组和的最大值,和最大值索引
            for i in range(len(self.sum_list)-1):
                for j in range(i+1, len(self.sum_list)):
                    if len(nums_list) % le == 0:
                        if self.sum_list[i] > self.sum_list[j]:
                            self.max_sum = self.sum_list[i]
                            self.max_index = i
                        else:
                            self.max_sum = self.sum_list[j]
                            self.max_index = j
                    else:
                        if self.sum_list[i] > self.sum_list[j]:
                            self.max_sum = self.sum_list[i]
                            self.max_index = i
                        else:
                            self.max_sum = self.sum_list[j]
                            self.max_index = j-1
            
            # 根据子数组和的最大值索引算出子数组在符数组中索引
            for i in range(self.max_index-1, self.max_index+le):
                self.sub_list.append(nums_list[i])
                
            print("传入的数组是{},{}个长度的连续子数组最大和为{},最大和的数组为{}".format(nums_list, le, self.max_sum, self.sub_list))
         
        # 求数组中的值的和 本次未用到
        def sumArray(self, num_list):
            sum = 0
            for i in range(len(num_list)):
                sum += num_list[i]
            return sum
            
            
    # Your MedianFinder object will be instantiated and called as such:
    if __name__ == '__main__':
        pass
        
        # obj = MedianFinder()
        # obj.addNum(1)
        # obj.addNum(2)
        # obj.addNum(4)
        # obj.addNum(3)
        # obj.addNum(5)
        # param_2 = obj.findMedian()
    
        s = Solution()
        # s.maxSubArray([1,2,3,4,5,6])
        s.maxSubArray([-1,2,1,0,0],3)
        

    注: 这是小编自行整理,仅仅是实现了功能,不设计算法,正确的解法如下:有待研究~~

    '''
    1. 暴力求解
    基本思路就是遍历一遍,用两个变量,一个记录最大的和,一个记录当前的和。时空复杂度貌似还不错......(时间复杂度 O(n)O(n),空间复杂度 O(l)O(l))
    '''
    class Solution:
        def maxSubArray(self, nums: List[int]) -> int:
            tmp = nums[0]
            max_ = tmp
            n = len(nums)
            for i in range(1,n):
                # 当当前序列加上此时的元素的值大于tmp的值,说明最大序列和可能出现在后续序列中,记录此时的最大值
                if tmp + nums[i]>nums[i]:
                    max_ = max(max_, tmp+nums[i])
                    tmp = tmp + nums[i]
                else:
                #当tmp(当前和)小于下一个元素时,当前最长序列到此为止。以该元素为起点继续找最大子序列,
                # 并记录此时的最大值
                    max_ = max(max_, tmp, tmp+nums[i], nums[i])
                    tmp = nums[i]
            return max_
            
    '''
    作者:pandawakaka
    链接:https://leetcode-cn.com/problems/maximum-subarray/solution/bao-li-qiu-jie-by-pandawakaka/
    来源:力扣(LeetCode)
    著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
    '''

      

  • 相关阅读:
    cocos2d-x 2.2 study ------------------------ 双击事件(转)
    cocos2d-x打包Android
    cocos2d-x在win7下的android交叉编译环境
    Cocos2d-x之CCImage深入分析
    Eclipse开发C/C++之使用技巧小结
    TortoiseSVN安装使用
    cocos2d-x 2.2 study ------------------------ CCCallFunC家族
    cocos2d-x改底层之动态改变UIListView中的某项在链表中的位置
    汇编语言,以10进制的方式显示数字
    JVM
  • 原文地址:https://www.cnblogs.com/jiyanjiao-702521/p/11718793.html
Copyright © 2011-2022 走看看