[Swift]LeetCode805. 數組的均值分割 | Split Array With Same Average

★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★
➤微信公衆號:山青詠芝(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:數組

  • The length of 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 }

Runtime: 604 ms
Memory Usage: 24.9 MB
 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 }
相關文章
相關標籤/搜索