最大连续子序列和Python

问题

给你一个整数list L, 如 L=[2,-3,3,50], 求L的一个连续子序列,使其和最大,输出最大子序列的和。 例如,对于L=[2,-3,3,50], 输出53

方法一:暴力破解
最简单的方法就是直接求解出所有的子序列之和,然后比较子序列之和,求出最大值。那么如何求解子序列呢?首先子序列的起始位置可能是任意的,结束位置也可以是任意的。可以一层循环确定子序列的起始位置,嵌套一层循环确定子序列的结束位置并求和,(这里我简化了,直接利用上一个子序列的结果进一步求和),添加到空列表中。

sums = 0
L_fy = []
for i in range(len(L)):
	for j in range(i, len(L)):
		sums += L[j]
        L_fy.append(sums)
    sums = 0
maxs = max(L_fy)
return maxs

改进一
这肯定是最基本的方法了,看看还能不能改进呢?一个改进的方法,就是在比较的时候,不用先存到列表里。计算出一个子序列和就与之前的最大值比较,得出当前的最大值。

maxs = L[0]   #最好不要设为0,因为下面比较的时候,如果全是负数,那最终就为0,明显是不对的。 
sums = 0
for i in range(len(L)):
    for j in range(i, len(L)):
      
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
《Boost程序探秘:深度解析C++准标准》是一本详细介绍Boost程序的书籍。Boost是一个开源的C++程序集合,提供了许多重要的功能和工具,帮助开发者更高效地开发C++应用程序。 《Boost程序探秘:深度解析C++准标准》首先介绍了Boost程序的概念、历史和发展。然后,逐一介绍了Boost的各个模块和组件,包括: 1. 智能指针:详细介绍了shared_ptr、scoped_ptr和weak_ptr等智能指针的使用方法和原理,帮助开发者更好地管理资源和避免内存泄漏。 2. 容器:介绍了各种常用的数据容器,如vector、map、set等,并介绍了它们在Boost中的实现和扩展功能。 3. 函数对象和算法:介绍了Boost中的函数对象和算法,其中包含了丰富的算法和函数对象,方便开发者进行各种数据处理和计算操作。 4. 正则表达式:详细介绍了Boost中正则表达式的使用,包括基本语法、匹配规则和替换操作等。 5. 多线程和并发:介绍了Boost中多线程和并发编程的相关模块,包括线程、互斥锁、条件变量等,帮助开发者编写高效的并发程序。 6. 其他模块:还介绍了Boost中的其他模块,如日期时间、解析、文件系统等,帮助开发者完成更多的任务和功能。 《Boost程序探秘:深度解析C++准标准》不仅介绍了Boost的具体用法,还深入解析了其实现原理和设计思想,帮助开发者更好地理解和使用Boost程序。对于想要提高自己的C++编程技能和加快开发效率的开发者来说,这本书是一本非常实用的参考资料。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值