【leetcode】Valid Triangle Number
题目:
Given an array consists of non-negative integers, your task is to count the number of triplets chosen from the array that can make triangles if we take them as side lengths of a triangle. Example 1:
Input: [2,2,3,4]
Output: 3
Explanation:
Valid combinations are:
2,3,4 (using the first 2)
2,3,4 (using the second 2)
2,2,3
Note:
The length of the given array won't exceed 1000.
The integers in the given array are in the range of [0, 1000].
解析:
首先如何判断三个边长能否组成一个三角形,这个初中数学就学过——两个小边的和大于最大边的边长。
def checkValid(self,a,b,c):
return (a+b) > c
因此,很容易得到解法,对nums数组排序后,做全排列,依次检查每种组合是否符合要求。
def triangleNumber2(self, nums):
"""
:type nums: List[int]
:rtype: int
"""
count = 0
nums.sort()
for i in range(0,len(nums)-2):
for j in range(i+1,len(nums)-1):
for k in range(j+1,len(nums)):
if True == self.checkValid(nums[i], nums[j], nums[k]):
count += 1
#print nums[i], nums[j], nums[k]
else:
break
return count
但是非常遗憾,这种解法的复杂度是 O(n*3),超时了。根据判定中给出的超时输入发现,nums里面很多边长的数值是相同的。
Last executed input:
[33,97,81,65,30,58,83,83,66,85,78,40,51,61,86,94,42,17,35,18,45,27,56,78,36,97,6,51,76,26,68,68,61,87,13,98,93,80,24,34,19,90,85,89,83,15,41,52,25,16,61,51,19,6,40,79,25,88,65,85,0,42,78,27,30,68,47,67,40,26,15,72,20,45,88,82,12,82,95,1,46,56,83,20,65,39,13,92,36,99,74,50,46,8,27,45,36,55,50,0]
因此可以考虑优化算法,首先统计三个边长都不一样的情况,然后再考虑等腰三角形的情况,最后是等边三角形。
def triangleNumber(self, nums):
"""
:type nums: List[int]
:rtype: int
"""
#用一个list计数所有边长出线的次数,下标是边长值,对应的值是边长值出现的次数
count = 0
l = []
for i in range(0,1000+1):
l.append(0) for i in nums:
l[i] += 1
for i in range(1,len(l)-2):
if l[i] == 0:
continue
for j in range(i+1,len(l)-1):
if l[j] == 0:
continue
for k in range(j+1,len(l)):
if l[k] == 0:
continue
if True == self.checkValid(i,j,k):
count += (l[i]*l[j]*l[k])
else:
break
#dup
for i in range(1,len(l)):
if l[i] == 0 or l[i] == 1:
continue
else:
#print 'i:',i
#等腰三角形,如果某个边长值的出线的次数为n(n>=2),表示可以组成等腰三角形。根据组合的原理,两个腰可以得到C(2,n)
#然后根据 2*边长值与其他非自身边长值进行比较,得到等腰三角形的数量
for j in range(1,len(l)):
if 2*i > j and l[j] > 0 and j != i:
count += (l[i]*(l[i]-1))/2*l[j]
#等边三角形,这个也是组合,如果某个边长值的出线的次数为n(n>=3),表示可以组成等边三角形。
#根据组合的原理,可以等到的种数为C(3,n)
if l[i] >= 3:
count += (l[i]*(l[i]-1)*(l[i]-2))/6 return count
这样优化之后,效率得到了很大的提升,但是还是不够。进一步检查发现,list中无效的元素太多,可以考虑过滤掉很多边长值出现次数为0的元素,如代码所示,用一个ul对l中的数据进行过滤。
def triangleNumber3(self, nums):
"""
:type nums: List[int]
:rtype: int
"""
count = 0
l = []
for i in range(0,1000+1):
l.append(0) for i in nums:
l[i] += 1
#print l
ul = []
for i in range(0,len(l)):
if l[i] > 0:
ul.append(i)
#print ul
for i in range(0,len(ul)-2):
for j in range(i+1,len(ul)-1):
for k in range(j+1,len(ul)):
if True == self.checkValid(ul[i],ul[j],ul[k]):
count += (l[ul[i]]*l[ul[j]]*l[ul[k]])
#print i,j,k
else:
break
#dup
#print count
for i in range(0,len(ul)):
if l[ul[i]] == 0 or l[ul[i]] == 1 or ul[i] == 0:
continue
else:
#print 'i:',i
for j in range(0,len(ul)):
if 2*ul[i] > ul[j] and l[ul[j]] > 0 and j != i and ul[j] != 0:
#print (l[i]*(l[i]-1))/2
count += (l[ul[i]]*(l[ul[i]]-1))/2*l[ul[j]]
#print count
if l[ul[i]] >= 3:
count += (l[ul[i]]*(l[ul[i]]-1)*(l[ul[i]]-2))/6 return count
这样再一优化之后,终于通过了。
【leetcode】Valid Triangle Number的更多相关文章
- 【LeetCode】120. Triangle 解题报告(Python)
[LeetCode]120. Triangle 解题报告(Python) 作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 题目地址htt ...
- 【LeetCode】306. Additive Number 解题报告(Python)
[LeetCode]306. Additive Number 解题报告(Python) 标签(空格分隔): LeetCode 作者: 负雪明烛 id: fuxuemingzhu 个人博客: http: ...
- 【LeetCode】375. Guess Number Higher or Lower II 解题报告(Python)
[LeetCode]375. Guess Number Higher or Lower II 解题报告(Python) 作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://f ...
- 【LeetCode】137. Single Number II 解题报告(Python)
[LeetCode]137. Single Number II 解题报告(Python) 标签: LeetCode 题目地址:https://leetcode.com/problems/single- ...
- 【LeetCode】452. Minimum Number of Arrows to Burst Balloons 解题报告(Python)
[LeetCode]452. Minimum Number of Arrows to Burst Balloons 解题报告(Python) 标签(空格分隔): LeetCode 题目地址:https ...
- Leetcode 之 Valid Triangle Number
611. Valid Triangle Number 1.Problem Given an array consists of non-negative integers, your task is ...
- leetcode 611. Valid Triangle Number 、259. 3Sum Smaller(lintcode 918. 3Sum Smaller)
这两个题几乎一样,只是说611. Valid Triangle Number满足大于条件,259. 3Sum Smaller满足小于条件,两者都是先排序,然后用双指针的方式. 611. Valid T ...
- 【leetcode】Valid Number
Valid Number Validate if a given string is numeric. Some examples:"0" => true" 0.1 ...
- LeetCode 611. Valid Triangle Number有效三角形的个数 (C++)
题目: Given an array consists of non-negative integers, your task is to count the number of triplets c ...
随机推荐
- Pytorch笔记 (1) 初始神经网络
一.人工神经元 上方人工神经元中: 输入 * 权重 ——> 相当于 人神经元中 树突的功能 各输入 相加 ,再做非线性变化f ——> 相当于胞体的功能 将非线性变化的结果输出 ——& ...
- oop理论
三大特性: 封装:把对象的属性和行为独立的一个整体,并尽可能的隐藏对象内部实现细节.增加安全性. 继承:从已有的类中派生出新的类,称为子类,子类继承父类的属性和行为,并能根据自己的需求扩展出新的行为. ...
- Windos下navcat连接虚拟机中的mysql
进入mysql命令行, 使用root用户,密码:youpassword(你的root密码)连接到mysql服务器: # mysql -u root -proot mysql>GRANT ALL ...
- 二叉平衡树AVL的插入与删除(java实现)
二叉平衡树 全图基础解释参考链接:http://btechsmartclass.com/data_structures/avl-trees.html 二叉平衡树:https://www.cnblogs ...
- 事务与Mysql隔离级别
事务 定义: 比如ABCD四个业务,作为一个事务,他们要么一起都执行完毕,要么都不执行.(只要有一个不成功,那么所有的都不可以成功) 四个特性 ACID 原子性(Atomicity) 整个事务中的所有 ...
- 【神经网络与深度学习】Caffe使用step by step:使用自己数据对已经训练好的模型进行finetuning
在经过前面Caffe框架的搭建以及caffe基本框架的了解之后,接下来就要回到正题:使用caffe来进行模型的训练. 但如果对caffe并不是特别熟悉的话,从头开始训练一个模型会花费很多时间和精力,需 ...
- docker安装jenkins自动化部署
Docker之Jenkins自动化部署 1.拉取jenkins镜像images(类比:java中的类) docker pull jenkinsci/jenkins:lts 或 docker pull ...
- mavn Nexus Repository Manager漏洞
https://www.secpulse.com/archives/112290.html
- Java基础(入门Java)
今天是学习Java的第一天,为了保证在暑假里持续高效的学习,决定每周写一篇博客汇报总结当周进度,以此来督促自己不断的向更深更远的方向迈进.Java刚刚入门,看到的人若觉得某些地方不妥欢迎进行批评指导, ...
- Codeforces 1156F Card Bag(概率DP)
设dp[i][j]表示选到了第i张牌,牌号在j之前包括j的概率,cnt[i]表示有i张牌,inv[i]表示i在mod下的逆元,那我们可以考虑转移,dp[i][j]=dp[i-1][j-1]*cnt[j ...