python3实现最大子序列和的在线处理方法

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)
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值