数组求最大值
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;
}
总结:这次作业让我们学到了很多,虽然遇到了很多问题,但是我们都解决了它。这些问题刚开始都没发现,最初我们想的太简单,等越做作业发现的问题越多,也就需要想办法去解决它,虽然比较麻烦,但我们最终还是解决了问题。
以上是关于数组求最大值的主要内容,如果未能解决你的问题,请参考以下文章