您的位置:首页 > 产品设计 > UI/UE

hdu5504 GT and sequence

2015-10-18 16:09 357 查看
#include <stdio.h>

#include <string.h>

#include <iostream>

#include <algorithm>

using namespace std;

int main()

{

int i,T,N,flag,k1,k2;

__int64 a[1170],num,ansf,ansz,ans;

scanf("%d",&T);

while(T--)

{

flag=num=k1=k2=0;

ans=ansf=ansz=1;

scanf("%d",&N);

for(i=0;i<N;i++)

scanf("%I64d",&a[i]);

sort(a,a+N);

for(i=N-1;i>=0;i--)

{

if(a[i]<=0) break;

ansz*=a[i];

k2=1;

}

for(i=0;i<N;i++)

{

if(a[i]>=0) break;

num++;

}

if((num%2==1)&&(num!=1))

for(i=0;i<num-1;i++)

{

ansf*=a[i];

k1=1;

}

else if((num==1)&&(k2==0)) { ansf*=a[0];k1=1;}

else if((num==1)&&(k2!=0)) { ansf=1;k1=1;}

else

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

{

ansf*=a[i];

k1=1;

}

if(k1||k2) ans=ansf*ansz;

else ans=0;

for(i=0;i<N;i++)

if(a[i]==0)

{

flag=1;

break;

}

if(flag)

{

if(ans>=0) printf("%I64d\n",ans);

else printf("0\n");

}

else printf("%I64d\n",ans);

}

return 0;

}

心得:刚开始做时看错题,后来想法错,然后改了思路按照题解思路,还是WA,注意负数个数为一的特例,此题WA了N次T_T,感觉想算法时的态度需端正,想的算法不对再去优化只会变得越来越麻烦。。。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: