求最大連續(xù)子序列和。給出一個(gè)序列,序列元素有正整數(shù)、0、負(fù)整數(shù),要求找到序列中的一個(gè)連續(xù)子序列,使得這個(gè)子序列中包含的所有元素之和最大,在和最大的前提下還要求該子序列包含的元素個(gè)數(shù)最多,輸出這個(gè)最大和以及該連續(xù)子序列中的元素個(gè)數(shù)、連續(xù)子序列中各個(gè)元素。例如序列-5,4,-1,4,2,-1,0,9,-4,3;最大連續(xù)子序列和為17,該連續(xù)子序列中的元素個(gè)數(shù)為7,該連續(xù)子序列為4,-1,4,2,-1,0,9。
算法描述如下:
(1)從第一個(gè)數(shù)開(kāi)始向后進(jìn)行累加,每次累加和若大于之前的最大和,則記錄此時(shí)的最大和與連續(xù)子序列的長(zhǎng)度、最后一個(gè)序列元素位置;
(2)若每次累加和等于之前的最大和但大于之前的最大長(zhǎng)度,則記錄此連續(xù)子序列的長(zhǎng)度、最后一個(gè)序列元素位置;
(3)若累加和小于0,則重新開(kāi)始記錄;
(4)若有符合條件的多個(gè)連續(xù)子序列,則輸出最先找到的連續(xù)子序列。
小明編寫(xiě)了一個(gè)實(shí)現(xiàn)該功能的VB程序,窗體加載時(shí),讀取n個(gè)序列數(shù)據(jù),依次存數(shù)組a,并顯示在文本框Text1中。單擊“計(jì)算”按鈕 Command1后,找出連加和最大的子序列,在標(biāo)簽Labe12上顯示最大連續(xù)子序列和,在 Label3上顯示該連續(xù)子序列的元素個(gè)數(shù),在 Label4上顯示該連續(xù)子序列。程序運(yùn)行界面如圖所示。

(1)序列“1,2,2,-5,0,7,8,-7,-1,9”的最大連續(xù)子序列和為1616。
(2)請(qǐng)?jiān)跈M線處填入合適的代碼。


【考點(diǎn)】編輯事件處理過(guò)程的代碼.
【答案】16
【解答】
【點(diǎn)評(píng)】
聲明:本試題解析著作權(quán)屬菁優(yōu)網(wǎng)所有,未經(jīng)書(shū)面同意,不得復(fù)制發(fā)布。
發(fā)布:2024/4/20 14:35:0組卷:0引用:1難度:0.5
相似題
-
1.根據(jù)AQI值判斷城市的空氣質(zhì)量。若城市的AQI值(整數(shù))不超過(guò)100則空氣質(zhì)量?jī)?yōu)良,否則空氣質(zhì)量有污染。當(dāng)輸入的AQI值為-1時(shí)則退出程序。不要更改程序結(jié)構(gòu),將題中的①②③④填入正確的語(yǔ)句。
city=input(“請(qǐng)輸入城市名:”)
AQI=int(input(“請(qǐng)輸入空氣質(zhì)量指數(shù)AQI的值:”))
①______ AQI!=-1:
if ②______:
print(city,“的空氣質(zhì)量?jī)?yōu)良。”)
③______:
print(city,“的空氣質(zhì)量有污染?!保?br />city=input(“請(qǐng)輸入城市名:”)
AQI=④(input(“請(qǐng)輸入空氣質(zhì)量指數(shù)AQI的值:”))
(1)序號(hào)①答案為
A.if
B.while
C.for
D.def
(2)序號(hào)②答案為
A.AQI>=100
B.AQI<=100
C.AQI>100
D.AQI<100
(3)序號(hào)③答案為
A.elif
B.break
C.if
D.else
(4)序號(hào)④答案為
A.int
B.float
C.str
D.else發(fā)布:2025/1/2 11:0:1組卷:0引用:0難度:0.4 -
2.一球從100米高度自由落下,每次落地后反跳回原高度的一半,再下落。編寫(xiě)一個(gè)C程序,求它在第10次落地時(shí),其經(jīng)過(guò)了多少米?第10次反彈多高?
發(fā)布:2025/1/2 11:0:1組卷:0引用:3難度:0.3 -
3.利用海倫公式求解三角形面積。已知a,b,c為三角形的三條邊長(zhǎng),p為三角形的半周長(zhǎng),即p=(a+b+c)/2,計(jì)算此三角形面積S的海倫公式為:
。不要更改程序結(jié)構(gòu),將題中的①②③填入正確的語(yǔ)句。
import math#導(dǎo)入數(shù)學(xué)模塊
def hl(a,b,c):#定義求三角形面積的函數(shù)
p=①
s=math.jye.ai(②)#sqrt用于計(jì)算算術(shù)平方根
return ③#返回面積的值
a,b,c=3,4,5#邊長(zhǎng)依次賦值
print(“此三角形的面積S為:“,hl(a,b,c))
A. (a+b+c)/2 B.p*(p-a)*(p-b)*(p-c)
C. (a+b+c)*2 D.s
(2)序號(hào)②答案為
A.(a+b+c)/2 B.p*(p-a)*(p-b)*(p-c)
C.(a+b+c)*2 D.(3+4+5)/2
(3)序號(hào)③答案為
A.p B.s
C.p*(p-a)*(p-b)*(p-c) D.0發(fā)布:2025/1/2 11:0:1組卷:0引用:0難度:0.4