勾股数

Posted lllyclh

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了勾股数相关的知识,希望对你有一定的参考价值。

1.问题描述

求100以内所有的勾股数

所谓勾股数,是指能够构成三角形三条边的三个正整数。

2.问题分析

勾股数,要符合a^2+b^2=c^2,而且任意两条边的和大于第三条边

这就要用到sqrt函数,就相当于不用平方了

c = (int)sqrt(a * a + b * b);
                if (c* c == a * a + b * b && a + b > c && a + c > b && b + c > a && c <= 100)//这里不要忘记是一百以内的

 

3.算法分析

穷举法,两个循环语句分别控制a,b,这样a和b的值能确定,它们的平方和等于c的平方,可以将a^2+b^2的平方根赋值给c,再去判断c的平方是不是等于a^2+b^2,是不是符合直角三角形

4.程序

#include<iostream>
#include<math.h>
using namespace std;
int main()

    int a, b, c, d = 0;
    for(a=0;a<=100;a++)
        for (b = a + 1; b <= 100; b++)
        
            c = (int)sqrt(a * a + b * b);//求c的值
                if (c* c == a * a + b * b && a + b > c && a + c > b && b + c > a && c <= 100)//判断c^2是不是等于a^2+b^2,然后两边之和大于第三边
                
                    cout << a << "  " << b << "  " << c << "  " << endl;//输出
                        cout << endl;//换个行
                
        
    cout << endl;

sqrt函数要包含头文件#include<math.h>

作用:
sqrt() 用来求给定值的平方根

求50以内的所有勾股数

告诉我多少组也可以?

勾股数一般形式:a=m^-n^,b=2mn,c=m^+n^,m,n∈N,m>n

要求:a,b,c≤100且(a,b,c)=1---->(m,n)=1

n=1,m=2时:(3,4,5);
n=1,m=4时:(15,8,17);
n=1,m=6时:(35,12,37);
n=1,m=8时:(63,16,65);
n=2,m=3时:(5,12,13);
n=2,m=5时:(21,20,29);
n=2,m=7时:(45,28,53);
n=2,m=9时:(77,36,85);
n=3,m=4时:(7,24,25);
n=3,m=8时:(55,48,73);
n=4,m=5时:(9,40,41);
n=4,m=7时:(33,56,65);
n=4,m=9时:(65,72,97);
n=5,m=6时:(11,60,61);
n=5,m=8时:(39,80,89);
n=6,m=7时:(13,84,85)。

∴100以内的勾股数共有以上16组。
参考技术A 勾股数可以由复整数的平方运算完整生成。
其原理如下:(a+bi)^2=a^2+2abi+(bi)^2=(a^2-b^2)+2abi,
|(a+bi)^2|=sqrt((a^2-b^2)^2+(2ab)^2)=a^2+b^2.
∴(a^2-b^2)^2+(2ab)^2=(a^2+b^2)^2

由此可以通过复整数的平方来遍历产生所有勾股数。
下面求100以下的所有勾股数。
a^2+b^2<100, ∴a<10, b<10。
由于对称性,不妨设a>b。

(2+i)^2=3+4i, (3,4,5);

(3+i)^2=8+6i, (8,6,10)与(3,4,5)存在倍数关系;
(3+2i)^2=5+12i, (5,12,13);

(4+i)^2=15+8i, (15,8,17);
(4+2i)^2=12+16i, (12,16,20)与(3,4,5)存在倍数关系;
(4+3i)^2=7+24i, (7,24,25);

(5+i)^2=24+10i, (24,10,26)与(5,12,13)存在倍数关系;
(5+2i)^2=21+20i, (21,20,29);
(5+3i)^2=16+30i, (16,30,34)与(15,8,17)存在倍数关系;
(5+4i)^2=9+40i, (9,40,41);

(6+i)^2=35+12i, (35,12,37);
(6+2i)^2=32+24i, (32,24,40)与(3,4,5)存在倍数关系;
(6+3i)^2=27+36i, (27,36,45)与(3,4,5)存在倍数关系;
(6+4i)^2=20+48i, (20,48,52)与(5,12,13)存在倍数关系;
(6+5i)^2=11+60i, (11,60,61);

(7+i)^2=48+14i, (48,14,50)与(7,24,25)存在倍数关系;
(7+2i)^2=45+28i, (45,28,53);
(7+3i)^2=40+42i, (40,42,58)与(21,20,29)存在倍数关系;
(7+4i)^2=33+56i, (33,56,65);
(7+5i)^2=24+70i, (24,70,74)与(35,12,37)存在倍数关系;
(7+6i)^2=13+84i, (13,84,85);

(8+i)^2=63+16i, (63,16,65);
(8+2i)^2=60+32i, (60,32,68)与(15,8,17)存在倍数关系;
(8+3i)^2=55+48i, (55,48,73);
(8+4i)^2=48+64i, (48,64,80)与(3,4,5)存在倍数关系;
(8+5i)^2=39+80i, (39,80,89);
(8+6i)^2=28+96i, (28,96,100)与(7,24,25)存在倍数关系, 最大值等于100;*
(8+7i)^2=15+112i, (15,112,113), 最大值超过100;*

(9+i)^2=80+18i, (80,18,82)与(9,40,41)存在倍数关系;
(9+2i)^2=77+36i, (77,36,85);
(9+3i)^2=72+54i, (72,54,90)与(3,4,5)存在倍数关系;
(9+4i)^2=65+72i, (65,72,97);
(9+5i)^2=56+90i, (56,90,106)与(45,28,53)存在倍数关系, 最大值超过100;*
(9+6i)^2=45+108i, (45,108,117)与(5,12,13)存在倍数关系, 最大值超过100;*
(9+7i)^2=32+126i, (32,126,130)与(63,16,65)存在倍数关系, 最大值超过100;*
(9+8i)^2=17+144i, (17,144,145), 最大值超过100;*

所以100以下的勾股数共有30组,其中独立的有16组。
50以下的勾股数共13组,其中独立的有7组。
独立的条件:a,b不能同时为奇数,不能同时为偶数,且a,b互素。
参考技术B 4 3 5 6 8 10 5 12 13……

以上是关于勾股数的主要内容,如果未能解决你的问题,请参考以下文章

勾股数

勾股数

华为OD机试真题 Python 实现勾股数元组

2022华为机试真题 C++ 实现勾股数元组

迅雷笔试题_素勾股数的个数

华为OD机试 - 勾股数元组(Java) | 机试题+算法思路+考点+代码解析 2023