memset问题,求解释
#include<iostream>usingnamespacestd;inthash1[1000010];inthash2[1000010];intmain(){int...
#include<iostream>
using namespace std;
int hash1[1000010];
int hash2[1000010];
int main()
{
int a,b,c,d;
int i,j;
while(scanf("%d%d%d%d",&a,&b,&c,&d)!=EOF)
{
memset(hash1,0,sizeof(hash1));
memset(hash2,0,sizeof(hash2));//为什么超时,去掉一个改成for循环就不超
if((a > 0 && b > 0 && c > 0 && d > 0) || (a < 0 && b < 0 && c < 0 && d < 0))
{
printf("0\n");
continue;
}
int ans = 0, s;
for(i = 0; i <= 1000001; i++)
hash1[i] = hash2[i] = 0;
for(i = 1; i <= 100; i++)
{
for(j = 1; j <= 100; j++)
{
s = a * i * i + b * j * j;
if(s > 0)
hash1[s]++;
else
hash2[-s]++;
}
}
for(i = 1; i <= 100; i++)
{
for(j = 1; j <= 100; j++)
{
s = c * i * i + d * j * j;
if(s >= 0)
ans += hash2[s];
else
ans += hash1[-s];
}
}
printf("%d\n", 16 * ans);
}
return 0;
} 展开
using namespace std;
int hash1[1000010];
int hash2[1000010];
int main()
{
int a,b,c,d;
int i,j;
while(scanf("%d%d%d%d",&a,&b,&c,&d)!=EOF)
{
memset(hash1,0,sizeof(hash1));
memset(hash2,0,sizeof(hash2));//为什么超时,去掉一个改成for循环就不超
if((a > 0 && b > 0 && c > 0 && d > 0) || (a < 0 && b < 0 && c < 0 && d < 0))
{
printf("0\n");
continue;
}
int ans = 0, s;
for(i = 0; i <= 1000001; i++)
hash1[i] = hash2[i] = 0;
for(i = 1; i <= 100; i++)
{
for(j = 1; j <= 100; j++)
{
s = a * i * i + b * j * j;
if(s > 0)
hash1[s]++;
else
hash2[-s]++;
}
}
for(i = 1; i <= 100; i++)
{
for(j = 1; j <= 100; j++)
{
s = c * i * i + d * j * j;
if(s >= 0)
ans += hash2[s];
else
ans += hash1[-s];
}
}
printf("%d\n", 16 * ans);
}
return 0;
} 展开
1个回答
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询
广告 您可能关注的内容 |