UVALive 6862——结论题&&水题

题目

链接

题意:求满足$0 \leq x \leq y \leq z \leq m$且$x^j + y^j = z^j, \ j=2 \cdots n$的三元组的对数

分析

由费马大定理:整数$n >2$时,关于$x, y, z$的方程  $x^n + y^n = z^n$ 没有正整数解。

因此,我们只需考虑$j=2$的情况。对于$j>2$时,只存在$x=0, \ y=z$的解.

 1 #include<bits/stdc++.h>
 2 using namespace std;
 3 
 4 typedef long long ll;
 5 int m, n;
 6 
 7 int  main()
 8 {
 9     while(scanf("%d%d", &m, &n)==2)
10     {
11         int ans = 0;
12         for(int i = 0;i <= m;i++)
13         for(int j = i;j <= m;j++)
14         {
15             //if(i + j <= m)  ans++;
16             int z = sqrt(i * i + j * j);
17             if(z * z == (i*i + j*j) && z <= m && z >= j) ans++;
18         }
19         printf("%d\n", ans + (n-2)*(m+1));
20     }
21     return 0;
22 }

 

posted @ 2019-07-13 19:25  Rogn  阅读(286)  评论(0编辑  收藏  举报