★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★
➤微信公衆號:山青詠芝(shanqingyongzhi)
➤博客園地址:山青詠芝(https://www.cnblogs.com/strengthen/)
➤GitHub地址:https://github.com/strengthen/LeetCode
➤原文地址: http://www.javashuo.com/article/p-czrmhhna-me.html
➤若是連接不是山青詠芝的博客園地址,則多是爬取做者的文章。
➤原文已修改更新!強烈建議點擊原文地址閱讀!支持做者!支持原創!
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★html
In a given integer array A, we must move every element of A to either list B or list C. (B and C initially start empty.)git
Return true if and only if after such a move, it is possible that the average value of B is equal to the average value of C, and B and C are both non-empty.github
Example : Input: [1,2,3,4,5,6,7,8] Output: true Explanation: We can split the array into [1,4,5,8] and [2,3,6,7], and both of them have the average of 4.5.
Note:數組
A
will be in the range [1, 30].A[i]
will be in the range of [0, 10000]
.給定的整數數組 A ,咱們要將 A數組 中的每一個元素移動到 B數組 或者 C數組中。(B數組和C數組在開始的時候都爲空)微信
返回true
,當且僅當在咱們的完成這樣的移動後,可以使得B數組的平均值和C數組的平均值相等,而且B數組和C數組都不爲空。ide
示例: 輸入: [1,2,3,4,5,6,7,8] 輸出: true 解釋: 咱們能夠將數組分割爲 [1,4,5,8] 和 [2,3,6,7], 他們的平均值都是4.5。
注意:spa
A
數組的長度範圍爲 [1, 30]
.A[i]
的數據範圍爲 [0, 10000]
.20mscode
1 class Solution { 2 func splitArraySameAverage(_ nums: [Int]) -> Bool { 3 let sum = nums.reduce(0, +) 4 let nums = nums.sorted() 5 let n = nums.count 6 if n < 2 { return false } 7 for i in 1...n / 2 where (sum * i) % n == 0 && dfs(nums, i, 0, sum * i / n) { return true } 8 return false 9 } 10 11 func dfs(_ nums: [Int], _ len: Int, _ idx: Int, _ sum: Int) -> Bool { 12 if sum == 0, len == 0 { return true } 13 if idx >= nums.count || len < 0 || sum < 0 { return false } 14 for i in idx..<nums.count { 15 if i > idx && nums[i] == nums[i - 1] { continue } 16 if dfs(nums, len - 1, i + 1, sum - nums[i]) { return true } 17 } 18 return false 19 } 20 }
1 class Solution { 2 func splitArraySameAverage(_ A: [Int]) -> Bool { 3 if A.count < 2 {return false} 4 var sum:Int = A.reduce(0,+) 5 var n:Int = A.count 6 var m:Int = n / 2 7 var possible:Bool = false 8 var i:Int = 0 9 while(i <= m && !possible) 10 { 11 if sum * i % n == 0 {possible = true} 12 i += 1 13 } 14 if !possible {return false} 15 var dp:[Set<Int>] = [Set<Int>](repeating:Set<Int>(),count:m + 1) 16 dp[0].insert(0) 17 for num in A 18 { 19 for i in stride(from:m,through:1,by:-1) 20 { 21 for a in dp[i - 1] 22 { 23 dp[i].insert(a + num) 24 } 25 } 26 } 27 for i in 1...m 28 { 29 if sum * i % n == 0 && dp[i].contains(sum * i / n) 30 { 31 return true 32 } 33 } 34 return false 35 } 36 }