這篇文章將為大家詳細講解有關怎么在python中求大連續(xù)子數(shù)組的和,文章內(nèi)容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。
創(chuàng)新互聯(lián)憑借在網(wǎng)站建設、網(wǎng)站推廣領域領先的技術能力和多年的行業(yè)經(jīng)驗,為客戶提供超值的營銷型網(wǎng)站建設服務,我們始終認為:好的營銷型網(wǎng)站就是好的業(yè)務員。我們已成功為企業(yè)單位、個人等客戶提供了成都網(wǎng)站設計、成都做網(wǎng)站服務,以良好的商業(yè)信譽,完善的服務及深厚的技術力量處于同行領先地位。python的五大特點是什么python的五大特點:1.簡單易學,開發(fā)程序時,專注的是解決問題,而不是搞明白語言本身。2.面向對象,與其他主要的語言如C++和Java相比, Python以一種非常強大又簡單的方式實現(xiàn)面向對象編程。3.可移植性,Python程序無需修改就可以在各種平臺上運行。4.解釋性,Python語言寫的程序不需要編譯成二進制代碼,可以直接從源代碼運行程序。5.開源,Python是 FLOSS(自由/開放源碼軟件)之一。
拋出問題:
求一數(shù)組如 l = [0, 1, 2, 3, -4, 5, -6],求該數(shù)組的大連續(xù)子數(shù)組的和 如結果為[0,1,2,3,-4,5] 的和為7
問題分析:
這個問題很簡單,直接暴力法,上代碼。
# -*- coding:utf-8 -*- # 日期:2018/6/9 7:46 # Author:小鼠標 # 大連續(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))
分治法:
關鍵是暴力法的時間復雜度太高,所以就在原有的基礎上做了進一步的提升--分治法。
所謂分治法就是將原有的列表一分為二,那么大的子列表只有三種情況:
1、大子列表完全在左邊
2、大子列表完全在右邊
3、大子列表跨立在中間
所以我們分情況討論,求出答案。這種方法一定程度的降低了時間復雜度,從之前的n^2降到了(n/2)^2 + 2n
# -*- coding:utf-8 -*- # 日期:2018/6/9 7:46 # Author:小鼠標 # 大連續(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ī)劃:
即便是分治法,時間復雜度還是太高,不滿足生產(chǎn)的需求,所以如果說只求大子序列的和的值而不去追求大子序列本身,我們又引出一個方法--動態(tài)規(guī)劃
這種方法的時間復雜是是線性的,極大的降低了。
# -*- coding:utf-8 -*- # 日期:2018/6/9 8:38 # Author:小鼠標 def function(lists): max_sum = lists[0] pre_sum = 0 for i in lists: # 因為大子列表一定是從一個非0的數(shù)開始的(假定列表中有正數(shù)有負數(shù)) # 所以就可以暫時篩選調小于0的數(shù),即便列表全是負數(shù),那么大的子列表肯定是負數(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))
關于怎么在python中求大連續(xù)子數(shù)組的和就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。