码迷,mamicode.com
首页 > 编程语言 > 详细

数组1--求一个数的最大子数组

时间:2016-03-26 17:07:37      阅读:168      评论:0      收藏:0      [点我收藏+]

标签:

结对开发 我的队友是王春帆20132902博客园地址http://www.cnblogs.com/-beauTiFul/

/*
设计思路:
    输入数组 -3 4 2 -7 6 1
    a[0]=sz[0];-3
    a[1]=max(a[0]+sz[1],sz[1]);4
    a[2]=max(a[1]+sz[2],sz[2]);6
    a[3]=max(a[2]+sz[3],sz[3]);-1
    a[4]=max(a[3]+sz[4],sz[4]);6
    a[5]=max(a[4]+sz[5],sz[5]);7
    max(a[0],a[1]...a[n])
*/

#include<iostream>
#include <algorithm> 
#include<cstdio>
#include<vector>
using namespace std;

int main()
{
    int i, szgs, maxsum;
    int sz[100],a[100];//最大数组
    cout << "请输入数组元素个数:";
    cin >> szgs;
    cout << "请输入数组元素:";
    for (i = 0; i < szgs; i++)
    {
        cin>>sz[i];
    }
    a[0]=maxsum = sz[0];
    if (szgs>0)
    {
        for (i = 1; i < szgs; i++)
        {
            a[i] = max(a[i - 1] + sz[i], sz[i]);
            maxsum = max(maxsum, a[i]);
        }
    }
    cout << "最大子数组的和为:" << maxsum << endl;
}

 

技术分享

数组1--求一个数的最大子数组

标签:

原文地址:http://www.cnblogs.com/qinxian0/p/5323274.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!