HDU 3835R(N)(加點思維的暴力枚舉)

來源:互聯網
上載者:User

R(N)Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 1637    Accepted Submission(s): 853  Problem DescriptionWe know that some positive integer x can be expressed as x=A^2+B^2(A,B are integers). Take x=10 for example, 10=(-3)^2+1^2.We define R(N) (N is positive) to be the total number of variable presentation of N. So R(1)=4, which consists of 1=1^2+0^2, 1=(-1)^2+0^2, 1=0^2+1^2, 1=0^2+(-1)^2.Given N, you are to calculate R(N).  InputNo more than 100 test cases. Each case contains only one integer N(N<=10^9).  OutputFor each N, print R(N) in one line.  Sample Input26102565  Sample Output4081216HintFor the fourth test case, (A,B) can be (0,5), (0,-5), (5,0), (-5,0), (3,4), (3,-4), (-3,4), (-3,-4), (4,3) , (4,-3), (-4,3), (-4,-3)   Source2011 Multi-University Training Contest 1 - Host by HNU  題目大意:題目意思很好懂,找有多少組a,b可以滿足a^2+b^2==n.n最大是10^9,肯定不可以直接暴力枚舉。那就枚舉a>b>=0,這樣的情況。然後每一種情況會*4。a,b;a,-b;-a,b;-a,-b; 如果b=0的話,5,0;-5,0;0,-5,0,5;也是*4;詳見代碼。 題目地址:R(N) AC代碼:

#include<iostream>#include<cstring>#include<string>#include<cstdio>#include<cmath>using namespace std;int main(){    int n,i,a,b,ma,res;    while(~scanf("%d",&n))    {        ma=sqrt(double(n));  //最大的a,a>b>=0        res=0;        for(a=1;a<=ma;a++)        {            b=sqrt(double(n-a*a));            if(a*a+b*b==n)                res+=4;  //a,b;a,-b;-a,b;-a,-b;        }        cout<<res<<endl;    }    return 0;}//46MS 280K

 


相關關鍵詞:
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.