python3实现最大子序列和的在线处理方法
学习内容上传,便于复习和分享。
题目:
实现方法:使用在线处理的解题方法,这个方法的特点是从头至尾依次加上序列中的元素,每次加和后判断当前和(代码中的this_sum)是否大于零,若大于零继续累加,否则当前和置零并继续累加。运算过程中同时选择出最大的当前和作为输出结果。
此方法只用了一次循环,时间复杂度为n。
代码如下:
#input function
def inputNum():
k = int(input('请输入序列包含的整数个数:'))
if 0 < k <= 100000:
raw_number = input('请输入序列中的数字,以空格间隔:')
num_list_str = raw_number.split()
print(num_list_str)
else:
print('请输入小于100000的正整数!')
num_list = [int(i) for i in num_list_str]
print('输入的数字序列为:',num_list)
return num_list
#求最大子序列和函数
def MaxSubseqSum(sqe):
this_sum = 0
max_sum = 0
for i in range(len(sqe)):
this_sum += sqe[i]
if this_sum >= max_sum:
max_sum = this_sum
elif this_sum<0:
this_sum = 0
return max_sum
def main():
sqe = inputNum()
result = MaxSubseqSum(sqe)
print('最大子序列和为',result)
main()
个人认为代码中需要注意的地方:
1.本题中input()函数输入为带有空格的字符串格式,可使用split()函数将其分割为字符串列表,再将列表转化为int格式。转化方法有多种,可参考http://bbs.csdn.net/topics/340231280。
2.仔细理解实现方法,当前和置零的条件是当前和小于零。
3.在PTA上提交答案,要遵守格式要求,不要有额外的输;使用python时最好不好有中文注释;可以在结尾加上exit(0)语句(具体原因,我不是很清楚,请知道的大神告知一下);下面为PTA系统通过的代码:
#input function
def inputNum():
k = int(input())
raw_number = input()
num_list_str = raw_number.split()
num_list = [int(i) for i in num_list_str]
return num_list
def MaxSubseqSum(sqe):
this_sum = 0
max_sum = 0
for i in range(len(sqe)):
this_sum += sqe[i]
if this_sum >= max_sum:
max_sum = this_sum
elif this_sum<0:
this_sum = 0
return max_sum
def main():
sqe = inputNum()
result = MaxSubseqSum(sqe)
print(result)
main()
exit(0)