#define Inf 65535
#include <iostream>
using namespace std;
void FindMaxCrossingSubarray(int *Array, int low, int mid, int high,
int &maxLeft,int &maxRight, int &sum); void FindMaxmumSubarry(int *Array,int low,int high,
int &relow,int &rehigh,int &resum); void main()
{
int Array[]={,-,-,,-,-,
-,,,-,,-,-,,-,};
cout<<"分治策略,求最大子数组"<<endl;
int low,high,sum;
FindMaxmumSubarry(Array,,,low,high,sum);
cout<<"买入天数"<<low<<"卖出天数"<<high<<"总盈利"<<sum<<endl;
system("pause"); } void FindMaxCrossingSubarray(int *Array, int low, int mid, int high,
int &maxLeft,int &maxRight, int &sum)
{
int leftSum = -Inf;
sum=;
for(int i=mid;i>low;i--)
{
sum=sum+Array[i];
if(sum>leftSum)
{
leftSum=sum;
maxLeft=i;
}
} int rightSum = -Inf;
sum=;
for(int j=mid+;j<high;j++)
{
sum=sum+Array[j];
if(sum>rightSum)
{
rightSum=sum;
maxRight=j;
}
} sum=leftSum+rightSum;
}
void FindMaxmumSubarry(int *Array,int low,int high,
int &relow,int &rehigh,int &resum)
{
if (high==low)
{
relow=low;
high=rehigh;
resum=Array[low];
}
else
{
int mid=(low+high)/;
int leftLow,leftHigh,leftSum,
rightLow,rightHigh,rightSum,
crossLow,crossHigh,crossSum;
FindMaxmumSubarry(Array,low,mid,leftLow,leftHigh,leftSum);
FindMaxmumSubarry(Array,mid+,high,rightLow,rightHigh,rightSum);
FindMaxCrossingSubarray(Array,low,mid,high,crossLow,crossHigh,crossSum); if (leftSum>=rightSum&&leftSum>=crossSum)
{
relow=leftLow;
rehigh=leftHigh;
resum=leftSum;
}
else if(rightSum>=leftSum&&rightSum>=crossSum)
{
relow=rightLow;
rehigh=rightHigh;
resum=rightSum;
}
else
{
relow=crossLow;
rehigh=crossHigh;
resum=crossSum;
}
}
}

【算法导论C++代码】最大子数组的更多相关文章

  1. 【算法导论C++代码】Strassen算法

    简单方阵矩乘法 SQUARE-MATRIX-MULTIPLY(A,B) n = A.rows let C be a new n*n natrix to n to n cij = to n cij=ci ...

  2. 【算法导论C++代码】归并排序

    一个归并排序卡了一天最后还是归并算法有问题,最初是为了把算法导论的伪代码转到c++而加了一些东西,其中在对左右数组的赋值那里出了问题.因为进行测试时不完全,就是只用书上的数组进行测试时,归并算法部分还 ...

  3. 基于visual Studio2013解决算法导论之005原地随机排列数组

     题目 原地随机排列数组 解决代码及点评 #include <stdio.h> #include <stdlib.h> #include <malloc.h> ...

  4. 字符串匹配之KMP算法(续)---还原next数组

    相信通过今天的文章,你会对KMP的认识更加深入一层,不止停留在知道怎样计算的层面上了,废话不多说,開始. 通过前面的第一篇文章,知道了怎么求next数组,相信非常多喜欢刨根问底的人就会问,我依照你的做 ...

  5. 【Coding算法导论】第4章:最大子数组问题

    Coding算法导论 本系列文章主要针对算法导论一书上的算法,将书中的伪代码用C++实现 代码未经过大量数据测试,如有问题,希望能在回复中指出! (一)问题描述 给定一个数组,求数组中连续的子数组的和 ...

  6. 在Eclipse中使用Junit进行单元测试练习 实现最大子数组和算法

    1.如何在MAC OS X下安装配置java开发工具 http://www.cnblogs.com/coderL/p/5939541.html 2.最大子数组和算法 附上程序运行及测试截图,源码见后 ...

  7. ubuntu16.04下配置JDK 1.8+安装Java EE,并实现最大子数组算法

    软工第二次作业: 1.在个人电脑中安装一个集成开发环境(Microsoft Visual Studio.Eclipse或其它工具均可),要求该环境能够提供单元自动测试功能: 2.记录安装过程,并将全部 ...

  8. 【LeetCode-面试算法经典-Java实现】【053-Maximum Subarray(最大子数组和)】

    [053-Maximum Subarray(最大子数组和)] [LeetCode-面试算法经典-Java实现][全部题目文件夹索引] 原题 Find the contiguous subarray w ...

  9. 《算法导论》第二章demo代码实现(Java版)

    <算法导论>第二章demo代码实现(Java版) 前言 表示晚上心里有些不宁静,所以就写一篇博客,来缓缓.囧 拜读<算法导论>这样的神作,当然要做一些练习啦.除了练习题与思考题 ...

随机推荐

  1. tk界面版股票下载

    from tkinter import * import urllib.request import re,os import threading from tkinter import filedi ...

  2. hdu 2448(KM算法+SPFA)

    Mining Station on the Sea Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Jav ...

  3. hdu 3078(LCA的在线算法)

    Network Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Sub ...

  4. CSS3盒模型——box-sizing

    box-sizing盒模型是CSS3的一个重要属性之一,常常被很多人给忽略了!CSS3出现之前box-sizing盒模型默认的宽高是指内容的宽高,css3之后可以用box-sizing来指定宽高. 目 ...

  5. ThoughtWorks测试

    Fizz-Buzz-Whizz 问题描述: 1. 你首先说出三个不同的特殊数,要求必须是个位数,比如3.5.7. 2. 让所有学生拍成一队,然后按顺序报数. 3. 学生报数时,如果所报数字是第一个特殊 ...

  6. SpringBoot整合SpringSecurity简单实现登入登出从零搭建

    技术栈 : SpringBoot + SpringSecurity + jpa + freemark ,完整项目地址 : https://github.com/EalenXie/spring-secu ...

  7. logging模块介绍

    在我们的实际开发过程中,我们有时候需要记录一些重要操作,或者程序运行情况,我们就需要在程序里面写入日志,来达到更快的排错跟记录重要操作的目的.在Python中logging模块就很好的解决了这个问题, ...

  8. python之面向对象编程一

    概述: 面向过程:根据业务逻辑从上到下写垒代码 函数式:将某功能代码封装到函数中,日后便无需重复编写,仅调用函数即可 面向对象:对函数进行分类和封装,让开发“更快更好更强...” 面向过程编程最易被初 ...

  9. Codeforces Round #113 (Div. 2) Tetrahedron(滚动DP)

    Tetrahedron time limit per test 2 seconds memory limit per test 256 megabytes input standard input o ...

  10. StreamingAssets文件夹的读取异常

    1.今天在读取StreamingAssets文件夹中的文本文件的时候,出现了异常,花了一个多小时解决了,把解决结果给大家梳理一下 2.文本文件夹所在位置:在StreamingAssets文件夹中新建一 ...