标签:
Time Limit: 5000MS | Memory Limit: 65536K | |
Total Submissions: 14093 | Accepted: 6927 |
Description
Input
Output
Sample Input
37 29 41 43 47
Sample Output
654
Source
#include<iostream> #include<cstdio> #include<cstring> using namespace std; short hash[25000001]; //hash[sum]表示值等于sum的的解的个数(多对1映射) int main() //用int会MLE<span id="transmark"></span> { int a1,a2,a3,a4,a5; //系数 scanf("%d%d%d%d%d",&a1,&a2,&a3,&a4,&a5); { memset(hash,0,sizeof(hash)); for(int x1=-50; x1<=50; x1++) { if(!x1) continue; for(int x2=-50; x2<=50; x2++) { if(!x2) continue; int sum=(a1*x1*x1*x1+a2*x2*x2*x2); if(sum<0) sum+=25000000; hash[sum]++; } } int num=0; for(int x3=-50; x3<=50; x3++) { if(!x3) continue; for(int x4=-50; x4<=50; x4++) { if(!x4) continue; for(int x5=-50; x5<=50; x5++) { if(!x5) continue; int sum=a3*x3*x3*x3+a4*x4*x4*x4+a5*x5*x5*x5; if(sum>12500000||sum<-12500000) //防止特殊情况发生 continue; if(sum<0) sum+=25000000; if(hash[sum]) num+=hash[sum]; } } } cout<<num<<endl; } return 0; }
版权声明:本文为博主原创文章,未经博主允许不得转载。
标签:
原文地址:http://blog.csdn.net/became_a_wolf/article/details/47816555