算法第3章实践报告

算法第3章实践报告

 

1.实践题目名称

 

7-1 最大子段和

 

 

 

2.问题描述

 

给定n个整数(可能为负数)组成的序列a[1],a[2],a[3],…,a[n],求该序列如a[i]+a[i+1]+…+a[j]的子段和的最大值。当所给的整数均为负数时,定义子段和为0。要求算法的时间复杂度为O(n)。

 

 

 

3.算法描述

 

因为该题目要求算法的时间复杂度为O(n),所以可以采用动态规划的思想解决这个问题。

 

我们可以先把原问题拆分为子问题,原问题的解决依赖于子问题的解决。

 

我们用D[i] 记录第i个数到n的最大子段和

 

并且 if(a[i]>0) D[i]=D[i+1]+a[i];否则 D[i]=D[i+1]

 

该算法是通过递归实现的,当递归到D[n]时,终止递归。

 

如果 a[n]<=0,则D[n]=0;

 

如果a[n]>0,则D[n]=a[n]。

 

 

 

4.算法时间及空间复杂度分析

 

时间复杂度分析:
因为该算法只用了一个循环,只循环了一次数组,并且数组长度为n,所以时间复杂度为O(n)。

 

空间复杂度分析:

 

因为该算法还设置了一个变量来记录当前最大子段和,所以空间复杂度为O(1)。

 

 

 

5.心得体会

 

在本次实验课中,在做找最大子段和这个题目的时候,一开始会想到用数组来记录当前最大子段和,但是实践发现其实没有必要,直接用一个整型变量来记录就可以了。还有就是解决这类问题用动态规划的思想会让自己的算法思路更加清晰明了,并且一般情况下会降低时间复杂度。

 

 

 

6.动态规划的个人体会和思考

 

动态规划算法的基本要素是最优子结构性质,即原问题的最优解包含子问题的最优解,原问题依赖于子问题,和重叠子问题性质,具有这些性质的问题都可以用动态规划的算法来解决。在学习动态规划这一章内容,我学会了解决矩阵连乘问题,最长公共子序列问题,最大子段和问题,0-1背包问题等等,我感受到了动态规划在解决这些问题上的优势。在用动态规划这一算法时,我们也常常会用到填表的思想,这会大大降低时间复杂度。并且使用动态规划,会让我们的算法思路更加的清晰,让解决同类问题有一个很好的方式。

 

 

posted @   Linqylin  阅读(37)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 通过 API 将Deepseek响应流式内容输出到前端
· AI Agent开发,如何调用三方的API Function,是通过提示词来发起调用的吗
点击右上角即可分享
微信分享提示