|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
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;
}
|
|