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;
}
本文分享了一道编程题目的解决方案,重点在于处理数组元素相乘可能引起的long long类型溢出问题。通过预先设定溢出阈值并进行边界检查,确保了程序在遇到大数值时不会出现错误。同时,该方案还考虑了输入包含零的情况,进一步完善了解题思路。
255

被折叠的 条评论
为什么被折叠?



