鱼C论坛

 找回密码
 立即注册
查看: 3100|回复: 9

题目91:找出象限内直角三角形的数量

[复制链接]
发表于 2016-8-11 22:59:27 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 欧拉计划 于 2016-8-11 23:07 编辑
Right triangles with integer coordinates

The points QQ20160811-1@2x.png are plotted at integer co-ordinates and are joined to the origin, O(0,0), to form ΔOPQ.

QQ20160811-2@2x.png


There are exactly fourteen triangles containing a right angle that can be formed when each co-ordinate lies between 0 and 2 inclusive; that is,

QQ20160811-3@2x.png

QQ20160811-4@2x.png


Given that QQ20160811-5@2x.png , how many right triangles can be formed?


  题目:

QQ20160811-6@2x.png 位于整数点坐标上,并且与原点 O(0,0) 相连接形成三角形 ΔOPQ。

QQ20160811-2@2x.png


当横纵坐标都位于 0 到 2 之间时(包括 0 和 2),也就是 QQ20160811-3@2x.png 时,一共可以形成 14 个直角三角形。

QQ20160811-4@2x.png


给定 QQ20160811-5@2x.png , 一共能形成多少个直角三角形?
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2016-8-11 23:14:20 | 显示全部楼层
51
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2016-9-16 14:35:26 | 显示全部楼层
总共运行了10s,最笨的办法,结果14234。
  1. num=0
  2. for x1 in range(0,51):
  3.     for y1 in range(0,51):
  4.         for x2 in range(0,51):
  5.             for y2 in range(0,51):
  6.                 s1 = x1*x1 + y1*y1
  7.                 s2 = x2*x2 + y2*y2
  8.                 s3 = (x1-x2)*(x1-x2)+(y1-y2)*(y1-y2)
  9.                 f = [s1,s2,s3]
  10.                 f.sort()
  11.                 if f[0] >0:
  12.                     if f[0] + f[1] == f[2]:
  13.                         num+=1
  14.                         
  15. print(num/2)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2016-10-18 11:15:05 | 显示全部楼层
14234.0
[Finished in 5.1s]

  1. size = 50
  2. count = 0
  3. counted = []
  4. for x1 in range(0, size + 1):
  5.     for y1 in range(0, size + 1):
  6.         for x2 in range (0, size + 1):
  7.             for y2 in range(0, size + 1):
  8.                 c2 = x1**2 + y1**2
  9.                 a2 = (x2 -x1)**2 + (y2-y1)**2
  10.                 b2 = x2**2 + y2**2
  11.                 if (c2 == a2 + b2 or a2 == b2 + c2 or b2 == a2 + c2) and a2 != 0 and b2 != 0 and c2 != 0:
  12.                         count += 0.5
  13. print(int(count))
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2016-10-18 11:21:27 | 显示全部楼层
QingXin 发表于 2016-9-16 14:35
总共运行了10s,最笨的办法,结果14234。

和你的计算原理是一样的,但是比你快1倍的时间。
其实只要边长不为0即可,sort以后再额外判断2次很费时间的
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2016-10-19 21:34:34 | 显示全部楼层
jerryxjr1220 发表于 2016-10-18 11:21
和你的计算原理是一样的,但是比你快1倍的时间。
其实只要边长不为0即可,sort以后再额外判断2次很费时 ...

恩,确实应该一次判断出来,sort搞麻烦了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-3-6 15:36:36 | 显示全部楼层
  1. # encoding:utf-8
  2. # 象限内直角三角形个数
  3. from time import time

  4. def euler090(N=50):
  5.     count = 0
  6.     # 直角顶点在X轴(1,0)--(50,0)
  7.     count += 50 * 50
  8.     # 直角顶点在Y轴(0,1)--(0,50)
  9.     count += 50 * 50
  10.     # 直角顶点在原点(0,0)
  11.     count += 50 * 50
  12.     for x1 in range(1, 51):
  13.         for y1 in range(1, 51):
  14.             for x2 in range(0, 51):
  15.                 for y2 in range(1, 51):
  16.                     if not(x2 < x1 and y2 > y1):
  17.                         continue
  18.                     a = x1 * x1 + y1 * y1
  19.                     c = x2 * x2 + y2 * y2
  20.                     b = (x1 - x2) ** 2 + (y1 - y2) ** 2
  21.                     if c == a + b:
  22.                         count += 1
  23.     for x1 in range(1, 51):
  24.         for y1 in range(1, 51):
  25.             for x2 in range(1, 51):
  26.                 for y2 in range(0, 51):
  27.                     if not(x1 < x2 and y1 > y2):
  28.                         continue
  29.                     a = x1 * x1 + y1 * y1
  30.                     c = x2 * x2 + y2 * y2
  31.                     b = (x1 - x2) ** 2 + (y1 - y2) ** 2
  32.                     if c == a + b:
  33.                         count += 1
  34.     print(count)
  35. if __name__ == '__main__':
  36.     start = time()
  37.     euler090()
  38.     print('cost %.6f sec' % (time() - start))
复制代码

14234
cost 6.564656 sec
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-7-23 20:42:44 | 显示全部楼层
  1. from time import process_time as t
  2. t1=t()
  3. r=range(50+1)
  4. count=0
  5. for x1 in r:
  6.   for x2 in r:
  7.     for y1 in r:
  8.       for y2 in r:
  9.         if x1==x2 and y1==y2 or x1==0==y1 or x2==0==y2:continue
  10.         l=sorted([(x1-x2)**2+(y1-y2)**2,x1**2+y1**2,x2**2+y2**2])
  11.         if l[0]+l[1]==l[2]:count+=1
  12. print(f'运行结果:{count/2}\n运行时间:{t()-t1}s')
复制代码
运行结果:14234.0
运行时间:24.828125s
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-2-26 17:29:11 | 显示全部楼层
本帖最后由 guoquanli 于 2020-2-26 17:33 编辑
  1. /*功能函数,实现直角三角形个数的计算*/
  2. int calNumOfTag(int pointA){
  3.         int tagNum = 0;
  4.         int count = 0;
  5.         for(int x1 = 0; x1 <= pointA; x1++){
  6.                 for(int y1 = 0; y1<=pointA; y1++){
  7.                         for(int x2 = 0; x2 <= pointA; x2++){
  8.                                 for(int y2 = 0; y2<= pointA ; y2++){
  9.                                         if((x1 == x2 && y1 == y2)|| (x1 == 0 && y1 == 0) || (x2 ==0 && y2 == 0)){
  10.                                                 continue;
  11.                                         }
  12.                                         //count++;
  13.                                         //printf("符合条件的点的集合___%d____:A(%d,%d),B(%d,%d)\n",count,x1,y1,x2,y2);
  14.                                         //printf("*******\n");
  15.                                         int edge_1 = x1*x1 + y1*y1;
  16.                                         //printf("edge_1 = x1*x1 + y1*y1[%d]\n",edge_1);
  17.                                         int edge_2 = x2*x2 + y2*y2;
  18.                                         //printf("edge_2 = x2*x2 + y2*y2[%d]\n",edge_2);
  19.                                         int edge_3 = (x2 - x1)*(x2 - x1) + (y2 - y1)*(y2 -y1);
  20.                                         //printf("edge_3 = (x2 - x1)*(x2 - x1) + (y2 - y1)*(y2 -y1)[%d]\n",edge_3);
  21.                                         if(edge_1 + edge_2 == edge_3 || edge_1 + edge_3 == edge_2 || edge_3 + edge_2 == edge_1 ){
  22.                                                 tagNum++;
  23.                                                 //printf("能组成直角三角形的点是:B(%d,%d),C(%d,%d)\n",x1,y1,x2,y2);
  24.                                         }
  25.                                 }
  26.                         }
  27.                 }
  28.         }
  29.         return tagNum/2 ;
复制代码

答案:14234
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-7-4 10:11:43 | 显示全部楼层
应用矢量代数里的叉积和点积来做,速度非常快
  1. #include <iostream>
  2. using namespace std;

  3. int main(void)
  4. {
  5.   int N = 50;
  6.   int nCount = 0;
  7.   for (int x1 = 0; x1 <= N; ++x1)
  8.   {
  9.     for (int y1 = 0; y1 <= N; ++y1)
  10.     {
  11.       //遍历p1
  12.       if (x1 == 0 && y1 == 0)//去掉原点
  13.         continue;
  14.       for (int x2 = 0; x2 <= N; ++x2)
  15.       {
  16.         for (int y2 = 0; y2 <= N; ++y2)
  17.         {
  18.           //遍历p2
  19.           if ((x2 == 0 && y2 == 0) //去掉原点
  20.             || (x1*y2 - x2 * y1 >= 0))//始终保持p1到p2为顺时针方向(应用叉积性质)
  21.             continue;
  22.           if ((y1*y2 == -x1 * x2) //直角在O点(应用内积性质)
  23.             || (y1 * (y2 - y1) == -x1 * (x2 - x1)) //直角在p1点
  24.             || (y2 * (y1 - y2) == -x2 * (x1 - x2)))//直角在p2点
  25.             ++nCount;
  26.         }
  27.       }
  28.     }
  29.   }
  30.   cout << nCount << endl;
  31.   return 0;
  32. }
复制代码

评分

参与人数 1荣誉 +8 鱼币 +8 贡献 +5 收起 理由
永恒的蓝色梦想 + 8 + 8 + 5

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-5-11 16:06

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表