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,感觉想算法时的态度需端正,想的算法不对再去优化只会变得越来越麻烦。。。
#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,感觉想算法时的态度需端正,想的算法不对再去优化只会变得越来越麻烦。。。
相关文章推荐
- UI - DataBase
- Request
- UI - SaveFile
- kendoui分级显示
- UI - KVOAndImageDownLoader
- kendo ui (frozen column)
- UITextView: 响应键盘的 return 事件
- bond trading - requirement spec
- UI - RequestNetWork
- iOS:UIAlertController和UIAlertAction的详解
- UI - JSONParser
- HibernateQueryException: ClassNotFoundException: org.hibernate.hql.ast.HqlToken
- 关于LigerUI表单元素的动态替换
- UI - XMLParser
- 【IOS 开发学习总结-OC-55】故事板中 segue 的 push、modal、popover、replace、custom 学习笔记
- UI - Block
- C#中的string与stringbuilder有什么区别
- mysql uuid 性能调优
- String,StringBuffer与StringBuilder的区别
- EasyUI+js实现动态加载导航栏