「LeetCode算法精讲」从集合取3个点,组成最大三角形(Python)
off999 2025-04-26 20:24 29 浏览 0 评论
题目内容
给定包含多个点的集合,从其中取三个点组成三角形,返回能组成的最大三角形的面积。
示例:
输入: points = [[0,0],[0,1],[1,0],[0,2],[2,0]]
输出: 2
解释:
这五个点如下图所示。组成的橙色三角形是最大的,面积为2。注意:
- 3 <= points.length <= 50.
- 不存在重复的点。
- -50 <= pointsi <= 50.
- 结果误差值在 10^-6 以内都认为是正确答案。
来源:力扣(LeetCode)
链接:
https://leetcode-cn.com/problems/largest-triangle-area
解法效率
LeetCode的Python执行用时随缘,只要时间复杂度没有明显差异,执行用时一般都在同一个量级,仅作参考意义。
解法一(海伦公式求面积)
根据题意,我们最先想到的就是遍历所有可能的三个点的组合,找出能够组成的最大三角形面积。
在具体的实现中,我们使用海伦公式求三角形面积。实现如下:
def largestTriangleArea(self, points: List[List[int]]) -> float:
def distance(pp1, pp2):
return pow(pow(pp1[0] - pp2[0], 2) + pow(pp1[1] - pp2[1], 2), 0.5)
ans = 0
for i1 in range(len(points)):
p1 = points[i1]
for i2 in range(i1 + 1, len(points)):
p2 = points[i2]
for i3 in range(i2 + 1, len(points)):
p3 = points[i3]
a = distance(p1, p2)
b = distance(p1, p3)
c = distance(p2, p3)
p = (a + b + c) / 2
t = p * (p - a) * (p - b) * (p - c)
if t > 0:
s = pow(p * (p - a) * (p - b) * (p - c), 0.5) # 海伦公式求面积
ans = max(ans, s)
return round(ans, 2)解法二(顶点坐标求面积)
【思路】
我们发现海伦公式在求解三角形面积时,需要先计算三边长,再由三边长计算三角形面积,在计算过程中,需要3次开方运算,效率较低。
因为我们已知三角形的顶点坐标,所以我们可以直接使用如下公式。
已知三角形的三个顶点坐标A(x1,y1)、B(x2,y2)、C(x3,y3),则三角形面积为:
S=abs(x1*(y2-y3) + x2*(y3-y1) + x3*(y1-y2))/2
实现如下:
def largestTriangleArea(self, points: List[List[int]]) -> float:
ans = 0
for i1 in range(len(points)):
[x1, y1] = points[i1]
for i2 in range(i1 + 1, len(points)):
[x2, y2] = points[i2]
for i3 in range(i2 + 1, len(points)):
[x3, y3] = points[i3]
s = abs((x1 * (y2 - y3) + x2 * (y3 - y1) + x3 * (y1 - y2))) / 2
ans = max(ans, s)
return ans解法三(使用组合)
我们使用itertools中的组合函数,让我们的代码更优雅。
def largestTriangleArea(self, points: List[List[int]]) -> float:
return max(abs((x1 * (y2 - y3) + x2 * (y3 - y1) + x3 * (y1 - y2)))
for (x1, y1), (x2, y2), (x3, y3) in itertools.combinations(points, 3)) / 2- 上一篇:超详细的sql语句汇总
- 下一篇:最常用的Python标准库模块,你了解多少?
相关推荐
- ie缓存清理在哪里(ie缓存如何清除)
-
? 1、首先打开IE浏览器,选择IE浏览器的工具这一选项; 2、下一步选择工具中的Internet的选项; 3、下一步就是在Internet选项中的常规的选项中; 4、选择常规--浏览历史记录...
- 华为正版鸿蒙40电脑操作系统下载中文版
-
安装华为鸿蒙40系统正式版需要先下载官方固件包,然后将固件包放到手机内部存储或外部存储卡中。打开手机设置,选择系统更新,点击“手动更新”,选择已下载的固件包进行安装。安装前请备份重要数据并确保手机电量...
- 笔记本电脑哪个牌子好用又实惠
-
1.神舟优雅X4优点:1.35kg很轻巧,14英寸够便携固态硬盘,速度快,有背光键盘。缺点:配置较低,只能轻度办公,售后一般。2.攀升MaxBookP1优点:零噪音,金属机身,固态硬盘,大触摸板,背...
- 电脑一开机就进入bios界面(电脑开机就会进入bios)
-
原因一:你的BIOS电池没有电了。解决方式:更换电池即可原因二:没有软驱但启用了软驱解决:可将软驱禁用——开机按DEL进BIOS,选择:STANDARDCMOSFEATURESDRIVEA:...
- 电脑windows7旗舰版怎么样(电脑windows7旗舰版好不好)
-
win7旗舰版挺好使的不过现在可以选择更win10。Windows7旗舰版属于微软公司开发的Windows7操作系统系统系列中的功能最高级的版本,也被叫做终结版本,是为了取代WindowsXP...
- office2010老是弹出安装程序
-
没看到截图,最好是吧提示信息完整截图发上来。因为信息不会是仅仅“更改安装”几个字的。猜测是已经安装有Office2010了或原本的2010没有卸载干净。
- win8玩游戏稳定吗(win8的游戏win10能玩吗)
-
1、确定驱动是最稳定的公版驱动,新驱动不一定适合游戏不要贸然升级。 2、确定电源已经设置为高性能模式。3、游戏过程开个游戏加加,可以自动为你切换独显,并且自动释放内存。也可以通过它注意下CPU占用,如...
- win10系统更新版本(win10系统更新版本能回退吗)
-
win10怎么更新到1909版本win101909升级方法一:WindowsUpdate更新:1.依次点击开始—设置—更新和安全—windows更新—检查更新,需要更新补丁至最新,如果你经常不更新...
- win7升级win10要留多少空间(windows7升级windows10需要多长时间)
-
win7电脑在系统已经激活并且开启系统更新的情况下,符合条件的系统会在右下角弹出windows10免费升级,直接点击确定就开始升级了。或者下载win10安助手,运行软件后会自动下载windows1...
- 国外比较开放的浏览器(国外比较开放的浏览器推荐)
-
1、打开控制面板。2、点击“检查防火墙状态”。3、点击左侧“高级设置”。4、选中“入栈规则”。5、右侧点击“新建规则”。6、选择“端口”。7、选择“TCP”,选中“特定端口”并输入你要开发的端口,或者...
- 一健ghost下载(一键ghost v2015.07.05)
-
你的是原版镜像,当然无法识别。。你可以使用微软usb工具。将镜像写入U盘或光盘。
- 纯净无毒的win7下载(有没有纯净的win7系统)
-
下面提供的是微软发布的Windows7各版本光盘ISO镜像下载地址,原始文件均来源自MSDN,和零-售彩盒版本光盘内容完全一致。请放心下载。(如果需要光盘的买家,请无视以下内容)下...
- ie浏览器文件损坏怎么修复(ie浏览器破坏怎么恢复)
-
可以在浏览记录里面查到。重新下载一次就行了如果你在IE浏览器里面下载的文件被你不小心删掉了,而且这个文件对你来说很重要,你可以打开你的IE浏览器选择历史记录,在历史记录里面就可以找到相关的下载的地方,...
- 电脑没音量是什么原因(电脑没音量是什么原因造成的)
-
电脑突然没有声音可能是由于以下原因:1.音量设置被关闭或静音;2.音频驱动程序出现问题或需要更新;3.音频设备连接问题,例如音频插头没有插好或者有问题;4.操作系统的声音设置出现问题。解决方法包括检查...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
python入门到脱坑 输入与输出—str()函数
-
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
失业程序员复习python笔记——条件与循环
-
使用 python-fire 快速构建 CLI_如何搭建python项目架构
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
