结对开发~环形数组篇

实验题目

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

  要求:

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

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

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

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

  求所有子数组的和的最大值。要求时间复杂度为O(n).

实验思路

  由于这次所要求的子数组相当于一个环形的数组,所以就想到了类似数字右循环的形式来解决这个题目。(其实主要思想是参考的课堂上一个同学的思想)

  下面我用一个例子来说明一下我们的解题思路:

  例如,我输入的数组是{5,-3,2,-1}第一次循环求得5,和max比较大小,然后把5+(-3)和max比较大小,然后是5+(-3)+2和max比较大小,最后是5+(-3)+2+(-1)和max比较大小,把最大值给max,接下来把5移到-1的后面,再用同样的方法求第二次循环的最大值,只不过这次开始于-3。依次类推,求出最大的子数组。

  由于我和小伙伴编程不是太好,所以返回最大子数组的位置这一个要求没有实现。

源代码:

// 信1201-2班 司新红 万彤
#include"stdafx.h"
#include "iostream"
using namespace std;

/*主函数*/
int main()
{
    int length;//定义数组长度length
    int n;//定义变化后的数组的长度
    cout<<"请输入数组元素个数:"<<endl;
    cin>>length;
    n=2*length;
    int* a=new int[n];//初始化数组
    cout<<"请输入数组中的元素:"<<endl;
    for(int i=0;i<length;i++)
    {
        cin>>a[i];
    }
    int max=a[0];
    int s=0;//定义求和后的元素
     for(int i=0;i<length;i++)
     {
        s=0;
        for(int j=i;j<length+i;j++)
        {
            s=s+a[j];
            if(s>max)
            {
                max=s;
            }
        }
        a[length+i]=a[i];                                //每次将已经计算过的数放到最后
     }
     cout<<endl;
     cout<<"最大子数组的和为:"<<endl;
     cout<<max<<endl;

    return 0;
}

运行结果:

心得体会

这次的程序,在我刚刚看到的时候,简直一点思路都没有,所以最后采取的课堂上一个同学的思路,在编程的过程中我们还遇到了许多的问题,比如不知道如何把第一个数字移到数组的最后面,后来经过问同学,和我们自己的研究终于得到了解决。虽然我和我的小伙伴都不太会编程,但是我们还是努力完成了这个题目,也许这就是一点点的进步吧,在以后的过程中,我们会再接再厉,争取能够独立完成一个程序。

时间: 2024-10-16 09:30:10

结对开发~环形数组篇的相关文章

软件工程——结对开发环形数组

一.题目: 返回一个整数数组中最大子数组的和. 要求: 输入一个整形数组,数组里有正数也有负数. 数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和. 如 果数组A[0]……A[j-1]首尾相邻,允许A[i-1], …… A[n-1], A[0]……A[j-1]之和最大. 同时返回最大子数组的位置. 求所有子数组的和的最大值.要求时间复杂度为O(n). 二.设计思路 开始想的是用链表实现数组首尾相连,可是由于链表用着不太熟悉,便想了另一种算法: 当最大值未出现跨域是就按常规方法计算找

结对开发——环形一维数组求最大子数组和

题目:返回一个整数数组中最大子数组的和.要求:(1)输入一个整形数组,数组里有正数也有负数.(2)数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和.(3)如果数组A[0]……A[j-1]首尾相邻,允许A[i-1], …… A[n-1], A[0]……A[j-1]之和最大.(4)同时返回最大子数组的位置.(5)求所有子数组的和的最大值.要求时间复杂度为O(n).一.设计思想 这个问题的最优解一定是以下两种可能.可能一:最优解没有跨过array[n-1]到array[0],即和非环形数

软件工程课堂训练——结对开发之环数组最大和

一.题目及要求: 题目:返回一个整数数组中最大子数组的和 要求(新加):①如果数组A[0]...A[j-1]首尾相邻,允许A[i-1]...A[n-1],A[0]...A[j-1]之和最大:②同时返回最大子数组的位置. 结对人员:胡亚宝  焦燕 二.设计思路: 我们要解决两个问题:求出环数组中最大的子数组:并且定位出该子数组的位置,把它们的名称输出来.要解决这两个问题,我们从以下两个方面入手: ①求出最大子数组:将数组数值按顺序排好称为“一趟”,每求出一趟的最大子数组后,将第一个数值放到最后一个

结对开发——一维数组最大子数组判断溢出

一 题目 求一维数组最大子数组和 要求:1000个数以上,整数 二.设计思路 最大子数组很好找到,但是子数组和的溢出问题很难解决. 经过不断的思考,我得出了结论: 溢出是程程序设计者设计时的不足所带来的错误.所以设计者要在编码时便高度警惕,预防溢出的发生,这才是最本质的解决问题的方法.就本题而言,我们设置了元素最大个数,以及其它输入要求,尽量避免溢出的发生.1000个数相加可以实现,但非要取1000个最大的数相加,那样的计算没有意义,不会在我们的生活学习中出现,这属于科研问题,交给大神们来解决吧

结对开发——循环数组的最大值

一 题目要求: 返回一维数组中最大子数组的和 输入一个整形数组,数组里有正数也有负数. 数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和. 如果数组A[0]……A[j-1]首尾相邻,允许A[i-1], …… A[n-1], A[0]……A[j-1]之和最大. 同时返回最大子数组的位置. 求所有子数组的和的最大值. 要求时间复杂度为O(n) 二 设计思路:(结对思考以及参考于其他同学) 考虑到数组需要首尾相连,采取把数组的长度增加两倍,并把复制的数组写在在最后一个数的后面,这样在循环

结对开发-- 一维数组求和最大的子数组的大数溢出问题

结对人员:韩雪东,高扬 一.设计思路 对于大数溢出问题开始很迷茫,不大懂该干什么,思路匮乏.因为只要溢出这个数就不会被存储被改变,这样导致很难去判断溢出后该怎样做,但后来我们改变了一下思路,采用逆向思维,首先找到能存储的最大数,用它来减去将要运行的数,从而与即将要加的数比较,如果小了咋说明相加后会产生溢出,直接结束程序. 二.源代码 // ceshi.cpp : Defines the entry point for the console application. //作者:韩雪东,高扬 //

结对开发Ⅳ——一维数组求和最大的子数组(大数溢出)

一.设计思路 由于我们第一个版本的算法不太好,导致后来拓展的两个程序无法很好地实现,我们就又重新设计了一个.我们是先写的首尾相连的那个程序,在它的基础上稍微修改了一下. (1)数据结构是链表,存放数据和next指针: (2)生成特别大的随机数,数据也设置得比较多. 二.源代码 未调试好 1 // 一维最大子数组2.cpp : Defines the entry point for the console application. 2 // 袁佩佩 于海洋 3 4 #include "stdafx

结对开发 首尾相连数组

一.实验思路   按要求随机产生几个数,然后先求数组的最大子数组的最大值,然后再比较他们的最大值求出整个子数组的最大子数组和 付东:程序编码和思路讨论                    岳竞一:思路讨论,代码编程后的测试和审核 二.实验代码 #include<iostream.h> #include<stdlib.h> int Maxsum(int *a,int n)//一维数组的求最大 { int tempstart =0,sum=0,max=-1000;  int i; i

结对开发——求环形二维数组最大子矩阵和的问题

一.题目要求 输入一个二维整形数组,数组里有正数也有负数.二维数组首尾相接,象个一条首尾相接带子一样.数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和.求所有子数组的和的最大值.要求时间复杂度为O(n)题目:返回一个二维整数数组中最大子数组的和 二.解题思路 这次就在以前的基础上进行修改,先对二维数组进行了重构,形成一个环状二维数组,然后再用求二维数组子矩阵最大和的方法求得最终结果. 三.程序代码 1 #include "stdafx.h" 2 #include<i