输入n个元素组成的序列s,你需要找出一个乘积最大的连续子序列,如果这个最大的乘积不是正数,应输出-1(表示无解)。-1<=n<=18,-10<=s1<=10。
样例输入:
3
2 4 -3
5
2 5 -1 2 -1
样例输出:
8
20
【分析】连续子序列有两个要素,起点和终点,因此只需要枚举起点和终点即可,由于每个元素的绝对值不超过10,一共又不超过18个元素,最大可能的乘积不会超过10^18,可以用long long存下
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
int num[19];
int main()
{
int n;
long long ans;
while(~scanf("%d",&n)){
long long max=0;
for(int i=0;i<n;i++)
scanf("%d",&num[i]);
if(n==1&&num[0]<0){
printf("-1\n");
continue;
}
int i,j;
for(i=0;i<n;i++){
ans=1;
for(j=i;j<n;j++){
ans*=num[j];
if(ans>max) max=ans;
}
}
printf("%lld\n",max);
}
return 0;
}