博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
作业1
阅读量:5308 次
发布时间:2019-06-14

本文共 670 字,大约阅读时间需要 2 分钟。

3)教科书三本都想读:优先级为《代码大全》、《敏捷开发》、《重构》

4)从第二次作业开始每次都写效能分析的优化和单元测试。

5)思路一:一开始看到这个题目,有一个想法是分规模,比如数组为a[n],当子数组只有1个数时,比较各个子数组的和的大小,一直考虑到子数组有n个数,发现此种算法复杂度为O(n^3),放弃;

    思路二:考虑动态规划解法,对数组a[n],目标函数为b[1,j] = max{sum[j], b[1,j-1]}, j>1; b[1,1] = a[1].

               而sum[j]=max{sum[j-1]+a[j], a[j]}, j>1; sum[1] =a[1]. 很轻松地可以看出来,算法复杂度为O(n).这是两层的动态规划,需要维护两个数组,想了一个晚上才想出来。不过有了目标函数就好办了。

               具体算法如下:

1 int max(int a[], int n) 2 { 3       int max = a[0]; 4       int sum = a[0]; 5       int i; 6       for(i = 0; i < n; i++){ 7           sum = sum+a[i] > a[i] ? sum+a[i] : a[i]; 8           max = max > sum ? max : sum; 9       }10       return max;  11 }

 

 

转载于:https://www.cnblogs.com/mountainking/p/3333873.html

你可能感兴趣的文章
环套树
查看>>
java基础(一):我对java的三个环境变量的简单理解和配置
查看>>
arcgis api 4.x for js 结合 Echarts4 实现散点图效果(附源码下载)
查看>>
YTU 2625: B 构造函数和析构函数
查看>>
apache自带压力测试工具ab的使用及解析
查看>>
C#使用Xamarin开发可移植移动应用(2.Xamarin.Forms布局,本篇很长,注意)附源码
查看>>
jenkins搭建
查看>>
C#中使用Split分隔字符串的技巧
查看>>
eclipse的调试方法的简单介绍
查看>>
加固linux
查看>>
IPSP问题
查看>>
HNU 10362 A+B for Input-Output Practice (II)
查看>>
10.17动手动脑
查看>>
WPF中Image显示本地图片
查看>>
Windows Phone 7你不知道的8件事
查看>>
脚本删除文件下的文件
查看>>
实用拜占庭容错算法PBFT
查看>>
java的二叉树树一层层输出,Java构造二叉树、树形结构先序遍历、中序遍历、后序遍历...
查看>>
php仿阿里巴巴,php实现的仿阿里巴巴实现同类产品翻页
查看>>
Node 中异常收集与监控
查看>>