中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在python中求最大連續子數組的和

發布時間:2021-05-02 16:03:37 來源:億速云 閱讀:343 作者:Leah 欄目:開發技術

這篇文章將為大家詳細講解有關怎么在python中求最大連續子數組的和,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

python的五大特點是什么

python的五大特點:1.簡單易學,開發程序時,專注的是解決問題,而不是搞明白語言本身。2.面向對象,與其他主要的語言如C++和Java相比, Python以一種非常強大又簡單的方式實現面向對象編程。3.可移植性,Python程序無需修改就可以在各種平臺上運行。4.解釋性,Python語言寫的程序不需要編譯成二進制代碼,可以直接從源代碼運行程序。5.開源,Python是 FLOSS(自由/開放源碼軟件)之一。

拋出問題:

求一數組如 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中求最大連續子數組的和就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

海兴县| 广安市| 金乡县| 新郑市| 唐山市| 全南县| 柳江县| 海阳市| 新闻| 南宫市| 玉龙| 罗甸县| 海南省| 那坡县| 衡水市| 周口市| 石阡县| 盘山县| 民权县| 垣曲县| 友谊县| 开封县| 毕节市| 格尔木市| 长海县| 老河口市| 钦州市| 来凤县| 醴陵市| 烟台市| 罗源县| 奉新县| 建湖县| 平陆县| 阿克陶县| 华坪县| 台山市| 通山县| 舒城县| 木兰县| 周至县|