【MATLAB编程实例练习】-(34)直角三角形边长问题

这篇博客介绍了如何用两种方法编写代码,寻找具有特定周长的整数直角三角形的三边长度。重点在于实现函数,返回按最短边排序的边长数组,展示了在Cody挑战中解决该问题的思路和技术细节。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目

来源于Mathwork上的Cody,Problem 1103 - Right Triangle Side Lengths.

If p is the perimeter of a right angle triangle with integral length sides, { a, b, c }, there are exactly three solutions for p = 120.
{[20,48,52], [24,45,51], [30,40,50]}
Given any value of p, return a cell array whose elements are the sorted side lengths of a possible right triangle whose perimeter is p. Furthermore, the elements of the output should be sorted by their shortest side length.

代码

function c = right_triangle_sides(p)
  c={};
  m=1;
  for i=round(p/3):p
      A=(1:i).^2;
      for j=1:i
          if (sum(A(j)+(p-i-sqrt(A(j)))^2==i^2)>0) && (p-i-sqrt(A(j))>0)
              c{m}=[sqrt(A(j)),p-i-sqrt(A(j)),i];
              m=m+1;
              break;
          end
      end
  end
  c=c(end:-1:1);
end

其它优秀代码

function c = right_triangle_sides(p)
c = {};
for x=1:p
   for y=x:p
      v=[x y hypot(x,y)];
      if sum(v)==p
        c = [c v];
      end
   end
end
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值