环形数组最大子数组之和
2016-03-27 09:58
288 查看
题目:返回一个整数数组中最大子数组的和。
要求:
输入一个整形数组,数组里有正数也有负数。
数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和。
如果数组A[0]……A[j-1]首尾相邻,允许A[i-1],…… A[n-1],A[0]……A[j-1]之和最大。
同时返回最大子数组的位置。
求所有子数组的和的最大值。
合作伙伴:张江鹏 博客地址:http://home.cnblogs.com/u/gaara-zhang/
结对编程要求:
两人结对完成编程任务。
一人主要负责程序分析,代码编程。
一人负责代码复审和代码测试计划。
发表一篇博客文章讲述设计思想,出现的问题,可能的解决方案(多选)、源代码、结果截图、总结
设计思路:为了实现程序要求,这次我在程序代码外围加了一个循环,主要目的是变换数组,每一次循环让原数组向前进一个数,然后得到新的数组,然后在新的数组上进行动态规划,把每一次动态规划的最大值放到一个数组里再对这个数组求最大值,如此求得整个环形数组的最大值。
要求:
输入一个整形数组,数组里有正数也有负数。
数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和。
如果数组A[0]……A[j-1]首尾相邻,允许A[i-1],…… A[n-1],A[0]……A[j-1]之和最大。
同时返回最大子数组的位置。
求所有子数组的和的最大值。
合作伙伴:张江鹏 博客地址:http://home.cnblogs.com/u/gaara-zhang/
结对编程要求:
两人结对完成编程任务。
一人主要负责程序分析,代码编程。
一人负责代码复审和代码测试计划。
发表一篇博客文章讲述设计思想,出现的问题,可能的解决方案(多选)、源代码、结果截图、总结
设计思路:为了实现程序要求,这次我在程序代码外围加了一个循环,主要目的是变换数组,每一次循环让原数组向前进一个数,然后得到新的数组,然后在新的数组上进行动态规划,把每一次动态规划的最大值放到一个数组里再对这个数组求最大值,如此求得整个环形数组的最大值。
#include<iostream> using namespace std; int main() { int A[100], B[100], C[100]; int max(int A, int B); int length = 0;//用来记录数组长 int sumOfArray;//sumOfArray用于存放包含目前的子数组的和的最大值 int sum = 0;//sum用来存放不包含当前数的所有子数组的和的最大值 cout << "请输入数组:"; for (length = 0;;) { cin >> A[length]; length++; if (getchar() == '\n') { break; } } //这里做数组转换,每一次循环数组里的数就向前进一位,然后付给另一个数组 for (int i = 0; i < length; i++) { for (int j = 0; j < length; j++) { if ((i + j) > (length-1)) { B[j] = A[i + j - length]; } else { B[j] = A[j + i]; } } sumOfArray = B[0]; for (int k = 1; k < length; k++) { sum = max(sum, sumOfArray); sumOfArray = max((sumOfArray + B[k]), B[k]); } sumOfArray = max(sum, sumOfArray); C[i] = sumOfArray; } int maxNum = C[0]; for (int i = 0; i < length; i++) { if (C[i] > maxNum) { maxNum = C[i]; } } cout << "这个循环整数数组的子数组之和的最大值为:" << maxNum << endl; return 0; } int max(int A, int B) { if (A > B) { return A; } else { return B; } }
![](http://images2015.cnblogs.com/blog/900338/201603/900338-20160327095619198-1071832418.png)
相关文章推荐
- 进度条第四周
- js事件处理程序跨浏览器解决方案
- C语言基本概念之序列点
- 【phpcms-v9】怎样给网站前台的个别页面更换新的模板?
- canvas实现图片尺寸等比压缩并转换为base64字符串
- Win10 VS2013 Compile Intro - C2011 Error
- 小甲鱼数据结构02谈谈线性表
- 利用github和hexo一步步生成个人博客(1)---环境搭建
- 红糖水与白糖水的交换
- 第四周学习进度
- 让LoadRunner再次走下神坛
- HDU 5652 India and China Origins
- HDU 5651 xiaoxin juju needs help
- 【phpcms-v9】缓存目录caches下的各个文件的作用
- hdu1081 To The Max--DP(最大子矩阵和)
- [BZOJ2049][SDOI2008]Cave 洞穴勘测(LCT)
- Html - 对话箭头
- (a^b)%c和(a/b)%c
- 处理流程和数据流程
- Jquey里的同步请求和异步请求