勾股定理,西方称为毕达哥拉斯定理,它所对应的三角形现在称为:直角三角形。
已知直角三角形的斜边是某个整数,并且要求另外两条边也必须是整数。
求满足这个条件的不同直角三角形的个数。
【数据格式】
输入一个整数 n (0<n<10000000) 表示直角三角形斜边的长度。
要求输出一个整数,表示满足条件的直角三角形个数。
例如,输入:
5
程序应该输出:
1
再例如,输入:
100
程序应该输出:
2
再例如,输入:
3
程序应该输出:
0
资源约定:
峰值内存消耗 < 256M
CPU消耗 < 1000ms
package competion2020;
import java.util.Scanner;
public class 勾股定理 {
public static void main(String[] args) {
//c^2-b^2=a^2
//判断差可开方即可sqrt
int ans=0;
Scanner scanner=new Scanner(System.in);
int c=scanner.nextInt();
for (int b = 1;b < c; b++) {
double a=Math.sqrt(c*c-b*b);
String s=a+"";
int index=s.indexOf(".");//输出整数为4.0转化为字符串判断长度即可判断是否为整数
if (s.length()==index+2) {
ans++;
}
}
System.out.println(ans/2);
}
}