python 连续比较_python 最大连续子数组的和

抛出问题:

求一数组如 l = [0, 1, 2, 3, -4, 5, -6],求该数组的最大连续子数组的和 如结果为[0,1,2,3,-4,5] 的和为7

问题分析:

这个问题很简单,直接暴力法,上代码。

# -*- coding:utf-8 -*-

# 日期:2018/6/9 7:46

# Author:小鼠标

# 最大连续子数组的和

l = [0, 1, 2, 3, -4, 5, -6]

# 暴力求解

def violence(l = []):

maxVal = 0

x,y=0,0

for i in range(0,len(l)+1):

for j in range(0,len(l)+1):

res = sum(l[i:j])

if res > maxVal:

maxVal = res

x = i

y = j

return maxVal,x,y

maxVal, x, y = violence(l)

print(maxVal,(x,y))

分治法:

关键是暴力法的时间复杂度太高,所以就在原有的基础上做了进一步的提升--分治法。

所谓分治法就是将原有的列表一分为二,那么最大的子列表只有三种情况:

1、最大子列表完全在左边

2、最大子列表完全在右边

3、最大子列表跨立在中间

所以我们分情况讨论,求出答案。这种方法一定程度的降低了时间复杂度,从之前的n^2降到了(n/2)^2 + 2n

# -*- coding:utf-8 -*-

# 日期:2018/6/9 7:46

# Author:小鼠标

# 最大连续子数组的和

l = [0, 1, 2, 3, -4, 5, -6]

#暴力求解

def violence(l = []):

maxVal = 0

x,y=0,0

for i in range(0,len(l)+1):

for j in range(0,len(l)+1):

res = sum(l[i:j])

if res > maxVal:

maxVal = res

x = i

y = j

return maxVal,x,y

#分治法 想左扫 向右扫,求出两边的最大值

def left_or_right(l):

maxVal = 0

term = 0

for i in l:

term += i

if maxVal < term:

maxVal = term

return maxVal

def Separate():

middle = int(len(l)/2)

l1 = l[0:middle]

l2 = l[middle:len(l)]

#左半部分

maxVal1,x1,y1 = violence(l1)

#右半部分

maxVal2,x2,y2 = violence(l2)

#跨立在中间

max_right = left_or_right(l2)

max_left = left_or_right(l1[::-1])

maxVal3 = max_right + max_left

return max(maxVal1,maxVal2,maxVal3)

val = Separate()

print(val)

动态规划:

即便是分治法,时间复杂度还是太高,不满足生产的需求,所以如果说只求最大子序列的和的值而不去追求最大子序列本身,我们又引出一个方法--动态规划

这种方法的时间复杂是是线性的,极大的降低了。

# -*- coding:utf-8 -*-

# 日期:2018/6/9 8:38

# Author:小鼠标

def function(lists):

max_sum = lists[0]

pre_sum = 0

for i in lists:

# 因为最大子列表一定是从一个非0的数开始的(假定列表中有正数有负数)

# 所以就可以暂时筛选调小于0的数,即便列表全是负数,那么最大的子列表肯定是负数最大的一个

if pre_sum < 0:

pre_sum = i

else:

pre_sum += i

if pre_sum > max_sum:

max_sum = pre_sum

return max_sum

lists = [0, 1, 2, 3, -4, 5, -6]

print(function(lists))

python实现连续子数组的最大和

题目描述 HZ偶尔会拿些专业问题来忽悠那些非计算机专业的同学.今天测试组开完会后,他又发话了:在古老的一维模式识别中,常常需要计算连续子向量的最大和,当向量全为正数的时候,问题很好解决.但是,如果向量 ...

lintcode :continuous subarray sum 连续子数组之和

题目 连续子数组求和 给定一个整数数组,请找出一个连续子数组,使得该子数组的和最大.输出答案时,请分别返回第一个数字和最后一个数字的值.(如果两个相同的答案,请返回其中任意一个) 样例 给定 [-3, ...

剑指Offer(三十):连续子数组的最大和

.# 剑指Offer(三十):连续子数组的最大和 搜索微信公众号:'AI-ming3526'或者'计算机视觉这件小事' 获取更多算法.机器学习干货 csdn:https://blog.csdn.net ...

剑指Offer面试题:28&period;连续子数组的最大和

一.题目:连续子数组的最大和 题目:输入一个整型数组,数组里有正数也有负数.数组中一个或连续的多个整数组成一个子数组.求所有子数组的和的最大值.要求时间复杂度为O(n).例如输入的数组为{1,-2,3 ...

lintcode循环数组之连续子数组求和

v 题目:连续子数组求和 II 给定一个整数循环数组(头尾相接),请找出一个连续的子数组,使得该子数组的和最大.输出答案时,请分别返回第一个数字和最后一个数字的值.如果多个答案,请返回其中任意一个. ...

剑指Offer 连续子数组的最大和

题目描述 HZ偶尔会拿些专业问题来忽悠那些非计算机专业的同学.今天测试组开完会后,他又发话了:在古老的一维模式识别中,常常需要计算连续子向量的最大和,当向量全为正数的时候,问题很好解决.但是,如果向量 ...

剑指offer面试题31连续子数组的最大和

一.题目描述 HZ偶尔会拿些专业问题来忽悠那些非计算机专业的同学.今天测试组开完会后,他又发话了:在古老的一维模式识别中,常常需要计算连续子向量的最大和,当向量全为正数的时候,问题很好解决.但是,如果 ...

最大连续子数组问题2-homework-02

1) 一维数组最大连续子数组 如第homework-01就是一维数组的最大子数组,而当其首位相接时,只需多考虑子数组穿过相接的那个数就行了! 2)二维数组 算法应该和第一次的相似,或者说是将二维转化为 ...

编程算法 - 连续子数组的最大和 代码&lpar;C&rpar;

连续子数组的最大和 代码(C) 本文地址: http://blog.csdn.net/caroline_wendy 题目: 输入一个整型数组, 数组里有正数也有负数. 数组中一个或连续的多个整数组成一 ...

随机推荐

配置react native遇到的问题

折腾了两天终于解决了问题,一开始用模拟器是报如下图的错 然后用真机的时候又报下图的错 这个错误网上有很多解决方法,说是要降级处理,将build.gradle中的1.3.1改成1.2.3,但是改完之后问 ...

themepark模板中奇特的编码

编码问题虽然经常碰到,但通过编码来实现源代码加密的是第一次碰到.只能用神奇来形容. 而且研究了几个小时,没有想到解决办法.代码基本可以通过不断执行输出,但无法判断是何种编码.

怎样增加windows 系统的环境变量Path的默认长度的限制?

reg add "HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Session Manager\Environment" ...

ArrayList 转换为DataTable

, }; ArrayList list = new ArrayList(arr); var dt = new DataTable(); DataColumn dc = new DataColumn(& ...

【BASH】自己主动清理rman脚本备份文件

************************************************************************ ****原文:blog.csdn.net/clark_ ...

Android 新一代多渠道打包神器

欢迎大家关注腾讯云技术社区-博客园官方主页,我们将持续在博客园为大家推荐技术精品文章哦~ 作者:李涛 ApkChannelPackage是一种快速多渠道打包工具,同时支持基于V1签名和V2签名进行多渠 ...

MVVM -- CallMethodAction 和 InvokeCommandAction

MVVM实践教程   算算,从事Silverlight和WPF的开发也有1年多的时间了,虽然时间不算长,虽然还没有突出的成就,但是感觉也还算一般. 但是,从头至今都没有去认真研究和使用过MVVM,虽然 ...

C&plus;&plus;之异常捕获和处理

一.简介   在C++语言中,异常处理包括:throw表达式,try语句块,一套异常类.其中,异常类用于在throw表达式和相关的catch子句之间传递异常的具体信息.exception头文件定义了最 ...

基于Mapxtreme for JAVA的电子地图设计与实现

基于Mapxtreme for JAVA的电子地图设计与实现学生毕业设计,适合测绘类专业研究目标:        开发一个基于MapXtreme for JAVA的校园电子地图项目,使用MapInfo ...

c&num;拷贝整个文件夹到指定文件夹下&lpar;非递归&rpar;

public static void CopyEntireDir(string sourcePath, string destPath) { //Now Create all of the direc ...

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值