★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★
➤微信公衆號:山青詠芝(shanqingyongzhi)
➤博客園地址:山青詠芝(https://www.cnblogs.com/strengthen/)
➤GitHub地址:https://github.com/strengthen/LeetCode
➤原文地址:http://www.javashuo.com/article/p-mmrfnngm-md.html
➤若是連接不是山青詠芝的博客園地址,則多是爬取做者的文章。
➤原文已修改更新!強烈建議點擊原文地址閱讀!支持做者!支持原創!
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★html
Given an array A
of positive lengths, return the largest perimeter of a triangle with non-zero area, formed from 3 of these lengths.git
If it is impossible to form any triangle of non-zero area, return 0
. github
Example 1:數組
Input: [2,1,2]
Output: 5
Example 2:微信
Input: [1,2,1]
Output: 0
Example 3:ide
Input: [3,2,3,4]
Output: 10
Example 4:spa
Input: [3,6,2,3]
Output: 8
Note:code
3 <= A.length <= 10000
1 <= A[i] <= 10^6
給定由一些正數(表明長度)組成的數組 A
,返回由其中三個長度組成的、面積不爲零的三角形的最大周長。orm
若是不能造成任何面積不爲零的三角形,返回 0
。 htm
示例 1:
輸入:[2,1,2] 輸出:5
示例 2:
輸入:[1,2,1] 輸出:0
示例 3:
輸入:[3,2,3,4] 輸出:10
示例 4:
輸入:[3,6,2,3] 輸出:8
提示:
3 <= A.length <= 10000
1 <= A[i] <= 10^6
1 class Solution { 2 func largestPerimeter(_ A: [Int]) -> Int { 3 var best = 0 4 var A = A 5 A.sort(by: >) 6 for i in 0..<A.count-2 { 7 let j = i+1 8 let k = j+1 9 if A[i]+A[j]>A[k] && A[i]+A[k]>A[j] && A[j]+A[k]>A[i] { 10 best = max(best,A[i]+A[j]+A[k]) 11 } 12 } 13 return best 14 } 15 }
308ms
1 class Solution { 2 func largestPerimeter(_ A: [Int]) -> Int { 3 var sortedA = A.sorted() 4 5 var i = A.count - 1 6 var j = i - 1 7 var k = j - 1 8 9 while k >= 0 && sortedA[j] + sortedA[k] <= sortedA[i] { 10 i -= 1 11 j -= 1 12 k -= 1 13 } 14 15 return k >= 0 ? sortedA[i] + sortedA[j] + sortedA[k] : 0 16 } 17 }
312ms
1 class Solution { 2 func largestPerimeter(_ A: [Int]) -> Int { 3 var A = A 4 A.sort() 5 for i in (2...A.count-1).reversed(){ 6 if(A[i] < A[i-1] + A[i-2]){ 7 return A[i] + A[i-1] + A[i-2] 8 } 9 } 10 return 0 11 } 12 }
324ms
1 class Solution { 2 func largestPerimeter(_ A: [Int]) -> Int { 3 var A = A.sorted(by:<) 4 var n = A.count 5 for i in stride(from:n-3,through:0,by:-1) 6 { 7 if A[i] + A[i+1] > A[i+2] 8 { 9 return A[i] + A[i+1] + A[i+2] 10 } 11 } 12 return 0 13 } 14 }
1 class Solution { 2 func largestPerimeter(_ A:[Int]) -> Int { 3 return compare(A.sorted(by: > )) 4 } 5 func compare(_ array:[Int]) -> Int { 6 if array[0] >= array[1] + array[2] { 7 if array.count == 3 { 8 return 0 9 } else{ 10 var new = array 11 new.removeFirst() 12 return compare(new) 13 } 14 } else { 15 return array[0] + array[1] + array[2] 16 } 17 } 18 }