数组求最大值

Posted yikechaguazi

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了数组求最大值相关的知识,希望对你有一定的参考价值。

设计思想:输入一个个数为n的数组,①如果第一个数为负数则直接略过,从下一个数开始算,如若开始连续碰到负数则从遇到第一个正整数开始计算,若正数下一个数是正数则直接相加,若是负数则相加后与0比较,如果大于0就继续相加,小于0就重新开始程序。②如果数组里全是负数则取最大数。

遇到的问题:没有考虑全是负数的情况。

解决方案:全是负数找最大的一个负数,如果最大的数是负数, 就输出这个数。

源代码:

#include<iostream>

using namespace std;

int main ()

{

 int a[1000],max,max1,count,temp,num; //a[num]输入数组,max暂存最大值,count子数组的和

 count=0;

 max=0;

 temp=0;

 cout<<"请输入数组的个数:";

 cin>>num;

 cout<<"请输入"<<num<<"个整数(可正可负): "; //输入数组的值

 for (int i=0;i<num;i++)

  cin>>a[i];

 max1=a[0];

 for (int i=0;i<num;i++) //进行一次循环

 {

  while(a[i]<0&&count==0&&i<num) //如果a[i]<0并且count==0表示最初开始,或者已经存储了一个temp的值,可以跳过所有的负数

  {

    if(max1<a[i])

    max1=a[i];

    i++;

  }

  count+=a[i]; //进行累加                

    if(count<=(-a[i+1])) //如果累加的和比下一个数的相反数小则可以确定不能再继续累加

    {

     temp=count; //暂存count

     count=0;

    }

  

   if(max<=temp&&count!=0) //暂存最大值

   {

    max=temp;

   }

   if(count==0||count>max1)

   {

    max=max1;

   }

 }

   cout <<"子数组的最大和为"<<max<<endl;

   system("pause");

   return 0;

 

}

技术分享图片技术分享图片

总结:这次作业让我们学到了很多,虽然遇到了很多问题,但是我们都解决了它。这些问题刚开始都没发现,最初我们想的太简单,等越做作业发现的问题越多,也就需要想办法去解决它,虽然比较麻烦,但我们最终还是解决了问题。

以上是关于数组求最大值的主要内容,如果未能解决你的问题,请参考以下文章

JAVA编程求数组最大值和最小值

java传入一个数组 写一个求该数组的最大值的方法

c语言 输入五行六列的数组,求最大值

VB求数组中最大值和它的位置

vb,编写过程求一维数组中的最大值及其在数组中的位置(最好能把程序写下来)

js求数组中的最大值