|  | 
 
| 
x
马上注册,结交更多好友,享用更多功能^_^您需要 登录 才可以下载或查看,没有账号?立即注册  复制代码/*
  勾股定理,西方称为毕达哥拉斯定理,它所对应的三角形现在称为:直角三角形。
  已知直角三角形的斜边是某个整数,并且要求另外两条边也必须是整数。
  求满足这个条件的不同直角三角形的个数。
【数据格式】
输入一个整数 n (0<n<10000000) 表示直角三角形斜边的长度。
要求输出一个整数,表示满足条件的直角三角形个数。
例如,输入:
5
程序应该输出:
1
再例如,输入:
100
程序应该输出:
2
再例如,输入:
3
程序应该输出:
0
*/
#include <stdio.h>
int main()
{
    int i,j,n,cnt=0;
    scanf("%d",&n);
    for(i=1;i<n;i++)
        for(j=1;j<n;j++)
    {
        if(i+j>n&&i*i+j*j==n*n)
            cnt+=1;
    }
    printf("%d",cnt);
    return 0;
}
应该是编译器的原因,楼主如果能够贴出来具体的错误信息那更好了不过我用VC++6.0的话,编译运行是完全正确的
 不过楼主的代码逻辑是不是正确的?
 在下这么说,是因为楼主的代码跑出来当n = 5的时候,输出结果是2,也就是楼主的代码将3 4 5 和4 3 5这两个直接三角形判断成了两个三角形,不知在下这么说楼主理解不,所以我擅作主张,改了一下
 下面是代码
 #include <stdio.h>
 int main()
 {
 int i,j,n,cnt=0;
 scanf("%d",&n);
 for(i=1;i<n;i++){
 
 for(j=1;j<n;j++)
 {
 if(i+j>n && i*i+j*j==n*n)
 cnt+=1;
 }
 }
 printf("%d\n",cnt/2);
 return 0;
 
 }
 
 | 
 |