课堂练习----一个整数数组中最大子数组的和(2)

本次的题目是:返回一个整数数组中最大子数组的和

要求:

输入一个整形数组,数组里有正数也有负数。

数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和。

如果数组A[0]……A[j-1]首尾相邻,允许A[i-1],…… A[n-1],A[0]……A[j-1]之和最大。

同时返回最大子数组的位置。

求所有子数组的和的最大值。

分析:

这个题目是在上个题目的基础的加上数组首位相连,并该数组最大子数组的和,实现方法就是把环变成直线的方法,通过for循环,在每次循环中,把数组中的元素作为数组的起始位置,并把后面的元素依次放到另外一个数组中。对于新生成的数组,通过上一次的方法求出新数组的最大子数组的和,然后通过比较所有数组的最大子数组和,求出初始数组最大子数组的和。

2 4 7 -10

4 7 -10 2

7 -10 2 4

-10 2 4 7

代码:

#include<iostream>
using namespace std;
#define N 100
int main()
{
    int p,num,value,max,count=0;     
    int val[N];                                      //原始数组
    int Array[N];                                      //存放新生成的数组
    int ArrayMax[N];                                   //存放每个数组最大值
    int ArrayFisrtLast[N][N];                          //存放最大子数组的每个元素
    int ArrayNum[N][N];                               //存放最大子数组元素的个数
    cout<<"输入数的个数:";
    cin>>num;
    for(int i=0;i<num;i++)                             //输入元素
    {
        cin>>val[i];
    }
    for(int i=0;i<num;i++)
    { 
        int firstNum=0,lastNum=0,q=0;                   //最大子数组开始位置(firstNum),结束的位置(lastNum)
        value=0;
        p=i;
        for(int k=0;k<num;k++)                           //重新开辟一个新数组Array,存放以原始数组的每个元素开头的数组
        {
            p=p%num;
            Array[k]=val[p];
            p++;
        }
        max=0;
        for(int j=0;j<num;j++)                              //找出最大子数组
        {
            value=value+Array[j];  
            if(value>max)                                      //累加和大于max,累加和赋值给max              
            {
                max=value;
                lastNum=j;
            } 
            if(value<0)                                // 当前和小于0,重置为0  
            {
                value=0;
                firstNum=j+1;
            }
        }
        if(max<0)                                 // 最大和依然为0,说明数组中所有元素都为负值
        { 
            max=val[0];
            firstNum=0;
            lastNum=0;
            for(int j=0;j<num;j++)
            {
                if(max<Array[j])
                {
                    max=val[j];
                    firstNum=j;
                    lastNum=j;
                }
            }
        }
        ArrayMax[count]=max;
        for(int m=firstNum;m<=lastNum;m++)
         {
            ArrayFisrtLast[count][q]= Array[m];
            q++;
        }
        ArrayNum[count][0]=lastNum-firstNum+1;
        count++;
    }
    max=ArrayMax[0];
    int n=0;
    for(int i=0;i<count;i++)
    {
        if(max<ArrayMax[i])
        {
            max=ArrayMax[i];
            n=i;
        }
    }
    cout<<"最大子数组是:";
    for(int i=0;i<ArrayNum[n][0];i++)
    {
        cout<<ArrayFisrtLast[n][i]<<" ";
    }

    cout<<endl;
    cout<<"最大子数组的和为:";
    cout<<max<<endl;
    return 0;
}

截图:

项目计划总结:

日期&&任务 听课 编写程序 阅读相关书籍 网上查找资料 日总计
周一 100 70   15 195
周二   40 45   95
周三   50 45 35 120
周四 100 40 40   180
周五   90   15 105
周六     40 15 65
周日     45   45
周总

时间记录日志:

日期 开始时间 结束时间 中断时间 净时间 活动 备注
3/21 14:00 15:50 10 100 听课 软件工程上课
  21:00 21:25   20 阅读书籍  《构建之法》《梦断代码》
3/22 14:00 17:00 10 110 编程 编写老师布置的作业
  18:00 22:00 10 110 看书 《构建之法》《梦断代码》
3/23 21:00 21:30   30 编程 编写老师布置的作业
3/23 14:00 15:50 10 100 听课 软件工程上课
3/24 16:00 18:00   120 编程 编写老师布置的作业
3/25 9:00 9:30   30 看书 《构建之法》《梦断代码》
3/26 9:00 9:30   30 看书 《构建之法》《梦断代码》

缺陷记录日志:

日期 编号 类型 引入阶段 排除阶段 修复时间 修复缺陷
3月26日 1   编码 编码 2min  
         重复使用最大值max,使程序出现问题

照片:小组成员:杨涛  http://www.cnblogs.com/GloryYT/ 

原文地址:https://www.cnblogs.com/linumy/p/5326080.html