欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python求最大連續(xù)子數(shù)組的和

 更新時間:2018年07月07日 14:25:34   作者:7749ha  
這篇文章主要介紹了python求最大連續(xù)子數(shù)組的和,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

拋出問題:

求一數(shù)組如 l = [0, 1, 2, 3, -4, 5, -6],求該數(shù)組的最大連續(xù)子數(shù)組的和 如結(jié)果為[0,1,2,3,-4,5] 的和為7

問題分析:

這個問題很簡單,直接暴力法,上代碼。

# -*- coding:utf-8 -*-
# 日期:2018/6/9 7:46
# Author:小鼠標(biāo)

# 最大連續(xù)子數(shù)組的和
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))

分治法:

關(guān)鍵是暴力法的時間復(fù)雜度太高,所以就在原有的基礎(chǔ)上做了進(jìn)一步的提升--分治法。

所謂分治法就是將原有的列表一分為二,那么最大的子列表只有三種情況:

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

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

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

所以我們分情況討論,求出答案。這種方法一定程度的降低了時間復(fù)雜度,從之前的n^2降到了(n/2)^2 + 2n

# -*- coding:utf-8 -*-
# 日期:2018/6/9 7:46
# Author:小鼠標(biāo)

# 最大連續(xù)子數(shù)組的和
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) 

動態(tài)規(guī)劃:

即便是分治法,時間復(fù)雜度還是太高,不滿足生產(chǎn)的需求,所以如果說只求最大子序列的和的值而不去追求最大子序列本身,我們又引出一個方法--動態(tài)規(guī)劃

這種方法的時間復(fù)雜是是線性的,極大的降低了。

# -*- coding:utf-8 -*-
# 日期:2018/6/9 8:38
# Author:小鼠標(biāo)

def function(lists):
 max_sum = lists[0]
 pre_sum = 0
 for i in lists:
  # 因為最大子列表一定是從一個非0的數(shù)開始的(假定列表中有正數(shù)有負(fù)數(shù))
  # 所以就可以暫時篩選調(diào)小于0的數(shù),即便列表全是負(fù)數(shù),那么最大的子列表肯定是負(fù)數(shù)最大的一個
  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)) 

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 使用python3批量下載rbsp數(shù)據(jù)的示例代碼

    使用python3批量下載rbsp數(shù)據(jù)的示例代碼

    這篇文章主要介紹了使用python3批量下載rbsp數(shù)據(jù)的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • Python jieba庫分詞模式實例用法

    Python jieba庫分詞模式實例用法

    在本篇文章里小編給大家分享的是一篇關(guān)于Python jieba庫分詞模式實例用法,有興趣的朋友們可以學(xué)習(xí)參考下。
    2021-01-01
  • Python學(xué)習(xí)之字符串常用方法總結(jié)

    Python學(xué)習(xí)之字符串常用方法總結(jié)

    這篇文章主要為大家介紹了Python中字符串的幾個常用方法總結(jié),文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)Python字符串有一定幫助,需要的可以參考一下
    2022-03-03
  • pycharm修改界面主題顏色的方法

    pycharm修改界面主題顏色的方法

    今天小編就為大家分享一篇pycharm修改界面主題顏色的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-01-01
  • Python手繪可視化工具cutecharts使用實例

    Python手繪可視化工具cutecharts使用實例

    這篇文章主要介紹了Python手繪可視化工具cutecharts使用實例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-12-12
  • 使用Python寫個小監(jiān)控

    使用Python寫個小監(jiān)控

    最近使用python寫了個小監(jiān)控,為什么使用python?簡單、方便、好管理,Python如何實現(xiàn)簡單的小監(jiān)控,感興趣的小伙伴們可以參考一下
    2016-01-01
  • pycharm無法導(dǎo)入lxml的解決辦法

    pycharm無法導(dǎo)入lxml的解決辦法

    這篇文章主要介紹了pycharm無法導(dǎo)入lxml的解決辦法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • Python3 如何開啟自帶http服務(wù)

    Python3 如何開啟自帶http服務(wù)

    這篇文章主要介紹了Python3 開啟自帶http服務(wù)的操作方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-05-05
  • django之對django內(nèi)置的User模型進(jìn)行自定義擴(kuò)展方式

    django之對django內(nèi)置的User模型進(jìn)行自定義擴(kuò)展方式

    這篇文章主要介紹了django之對django內(nèi)置的User模型進(jìn)行自定義擴(kuò)展方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • python樹莓派紅外反射傳感器

    python樹莓派紅外反射傳感器

    這篇文章主要為大家詳細(xì)介紹了python樹莓派紅外反射傳感器,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-01-01

最新評論