这段代码的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;
} 没明白楼主说的错误是什么。。。语法应该是没错的吧,但是你只考虑了两边之和大于第三边,还有两边之差应该小于第三边啊 应该是编译器的原因,楼主如果能够贴出来具体的错误信息那更好了
不过我用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;
}
1 for循环可以i从1到n,而j从i到n。
2 可以只用一个for循环,用公式确定第三个数是不是正整数即可
3 你的i和j可以互换位置,所以结果多了一倍 tailor_long 发表于 2017-12-3 20:10
应该是编译器的原因,楼主如果能够贴出来具体的错误信息那更好了
不过我用VC++6.0的话,编译运行是完全正 ...
谢谢你了,我理解错了题目的意思,它这个里面的三角形是可以移动的,也就是说a和b 与 b和a是一种情况,我以为a和b这两条边是固定的
页:
[1]