zoukankan      html  css  js  c++  java
  • 结对开发之环形数组

    一、题目与要求

      题目:返回一个整数数组中最大子数组的和。
      要求:
        输入一个整形数组,数组里有正数也有负数。
        数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和。
        如果数组A[0]……A[j-1]首尾相邻,允许A[i-1], …… A[n-1], A[0]……A[j-1]之和最大。
        同时返回最大子数组的位置。
        求所有子数组的和的最大值。要求时间复杂度为O(n)

     
    二、设计思路

      1、在上一次求一维数组最大子数组的问题上,进行拓展,继续使用类似的求和方法

         2、应题目要求,这次的一位数组要首尾相连,允许A[i-1], …… A[n-1], A[0]……A[j-1]之和最大,所以我们采用课上的方法寻找最大值,将数组的元素进行扩展,即把数组除最后一个元素外从新拼接到尾部,形成一个环。


    三、代码

     #include <iostream.h>
     #define N 1000 
     int main(int argc, char* argv[])
     {
         int arry[N];
         int length;
    	 int max[N],max1;
         int maxweizhi[N];
         int value( int arry[],int length);
         cout<<"请输入要比较整数的个数:"<<endl;
         cin>>length;
         cout<<"请输入整数"<<endl;
         for(int i=0;i<length;i++)
         {
             cin>>arry[i];    
         }
          
         int num=0;
         for(int j=length;j<2*length-1;j++)      
         {
             arry[j]=arry[num];
             num++;
         }
     
         cout<<"由这几个数形成的环形数组";
         value(arry,2*length-1);
         return 0;
     }
     int value( int arry[],int length)
     {
         int max[N],max1;
         int maxweizhi[N];
         for(int j=0;j<(length+1)/2;j++)
         {
             int sum=0;
             max1=-9999999;
             int z=0;
             for(int i=j;i<(length+1)/2+j;i++)
             {
                 sum=sum+arry[i];
                 if(sum>=max1)
                 {
                     max1=sum;
                     z++;
                 }
             }
             max[j]=max1;
             maxweizhi[j]=z;
         
         }
         int fmax=max[0];
         int q=0;
         for(int i=0;i<(length+1/2);i++)
         {    
             if(max[i]>fmax)
             {
                 fmax=max[i];
                 q=i;
             }
         }
     
         int weizhi=maxweizhi[q];
     
         cout<<"最大子数组为:"<<endl;
         for(int num=q;num<q+weizhi;num++)
         {
             cout<<arry[num];
         }
     
         cout<<"其和为:  "<<fmax<<endl;
         return 0;
     }
    

     四、结果

    正常情况下结果如下:

    因为是最大字数组,所以零也是算在内的

    那么问题出现了。零元素是不是应该算在子数组内呢,这是个汉语的歧义。

    五、实验总结

    老师刚开始布置这道题的时候,我和小伙伴都是愁眉苦脸的,但是后来经过老师和同学们的集思广益,我们俩渐渐有了思路,问题得到了解决。

    得到经验有二:一是出现问题不要先想不会,要学会动脑。,请教老师和同学,从而开发大脑,得到解决方案。

    二是1+1>2,我认为我俩配合的很是默契,总是能想到一块,当然最好的问题就是减少了不必要的争论,但是同时也带来了一些问题,这

    就要求我们除了自己想破头脑,还得虚心向同学请教,然后自己动脑,变成自己东西。

  • 相关阅读:
    Mysql 数据库 表中列的操作
    FreeSWITCH版本更新
    shell脚本58问
    Wireshark 与 Tcpdump
    Mysql 中 int(3) 和 int(11) 的区别
    FreeSWITCH 基础
    FreeSWITCH 学习笔记(一)
    Mysql 复制表数据(表结构相同)
    Centos date 设置自定义时间
    Mysql 主键
  • 原文地址:https://www.cnblogs.com/tangxiandi/p/4376319.html
Copyright © 2011-2022 走看看