B题题目要注意的就是防止 越界炸long long 其他的就正常判断就好
#include<iostream>
#include<cstdio>
#include <stdio.h>
#include<algorithm>
#include<cstring>
#include<cmath>
#include<cstdlib>
#include<queue>
#include<map>
#include<vector>
#include <set>
#define ll long long
using namespace std;
ll a[500010];
ll sum=1;
ll inf=1e18;
int main()
{
int k=0;
int n;
cin>>n;
for(int i=0; i<n; i++)
{
cin>>a[i];
if(a[i]==0)
{
k=1;
}
}
if(k==1)
{
cout<<0<<endl;
return 0;
}
for(int i=0; i<n; i++)
{
if(a[i]>inf/sum)
{
cout<<-1<<endl;
return 0;
}
sum=sum*a[i];
}
cout<<sum<<endl;
return 0;
}