御笔剑客 发表于 2017-12-3 19:46:59

这段代码的if判断条件为什么错了?

/*
勾股定理,西方称为毕达哥拉斯定理,它所对应的三角形现在称为:直角三角形。

已知直角三角形的斜边是某个整数,并且要求另外两条边也必须是整数。

求满足这个条件的不同直角三角形的个数。

【数据格式】
输入一个整数 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;

}

Rezero 发表于 2017-12-3 20:07:27

没明白楼主说的错误是什么。。。语法应该是没错的吧,但是你只考虑了两边之和大于第三边,还有两边之差应该小于第三边啊

tailor_long 发表于 2017-12-3 20:10:43

应该是编译器的原因,楼主如果能够贴出来具体的错误信息那更好了
不过我用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;

}

BngThea 发表于 2017-12-3 21:11:02

1 for循环可以i从1到n,而j从i到n。
2 可以只用一个for循环,用公式确定第三个数是不是正整数即可
3 你的i和j可以互换位置,所以结果多了一倍

御笔剑客 发表于 2017-12-4 12:59:15

tailor_long 发表于 2017-12-3 20:10
应该是编译器的原因,楼主如果能够贴出来具体的错误信息那更好了
不过我用VC++6.0的话,编译运行是完全正 ...

谢谢你了,我理解错了题目的意思,它这个里面的三角形是可以移动的,也就是说a和b 与 b和a是一种情况,我以为a和b这两条边是固定的
页: [1]
查看完整版本: 这段代码的if判断条件为什么错了?