[Swift]LeetCode1029. 兩地調度 | Two City Scheduling

★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★
➤微信公衆號:山青詠芝(shanqingyongzhi)
➤博客園地址:山青詠芝(https://www.cnblogs.com/strengthen/
➤GitHub地址:https://github.com/strengthen/LeetCode
➤原文地址: http://www.javashuo.com/article/p-rjyusvcy-md.html 
➤若是連接不是山青詠芝的博客園地址,則多是爬取做者的文章。
➤原文已修改更新!強烈建議點擊原文地址閱讀!支持做者!支持原創!
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★html

There are 2N people a company is planning to interview. The cost of flying the i-th person to city A is costs[i][0], and the cost of flying the i-th person to city B is costs[i][1].git

Return the minimum cost to fly every person to a city such that exactly Npeople arrive in each city.github

Example 1:面試

Input: [[10,20],[30,200],[400,50],[30,20]]
Output: 110 Explanation: The first person goes to city A for a cost of 10. The second person goes to city A for a cost of 30. The third person goes to city B for a cost of 50. The fourth person goes to city B for a cost of 20. The total minimum cost is 10 + 30 + 50 + 20 = 110 to have half the people interviewing in each city.

Note:微信

  1. 1 <= costs.length <= 100
  2. It is guaranteed that costs.length is even.
  3. 1 <= costs[i][0], costs[i][1] <= 1000

公司計劃面試 2N 人。第 i 人飛往 A 市的費用爲 costs[i][0],飛往 B 市的費用爲 costs[i][1]app

返回將每一個人都飛到某座城市的最低費用,要求每一個城市都有 N 人抵達。spa

示例:code

輸入:[[10,20],[30,200],[400,50],[30,20]]
輸出:110
解釋:
第一我的去 A 市,費用爲 10。
第二我的去 A 市,費用爲 30。
第三我的去 B 市,費用爲 50。
第四我的去 B 市,費用爲 20。

最低總費用爲 10 + 30 + 50 + 20 = 110,每一個城市都有一半的人在面試。

提示:htm

  1. 1 <= costs.length <= 100
  2. costs.length 爲偶數
  3. 1 <= costs[i][0], costs[i][1] <= 1000

Runtime: 16 ms
Memory Usage: 19.3 MB
 1 class Solution {
 2     func twoCitySchedCost(_ costs: [[Int]]) -> Int {
 3         var base:Int = 0
 4         var n:Int = costs.count
 5         var cs:[Int] = [Int](repeating:0,count:n)
 6         for (index,cost) in costs.enumerated()
 7         {
 8             base += cost[0]
 9             cs[index] = cost[1] - cost[0]  
10         }
11         cs.sort()
12         for i in 0..<n/2
13         {
14             base += cs[i]
15         }
16         return base
17     }
18 }

16ms

 

 1 class Solution {
 2     func twoCitySchedCost(_ costs: [[Int]]) -> Int {
 3         var costDiff = costs.sorted(by: { $0[1] - $0[0]  > $1[1] - $1[0] })
 4         var minCost = 0
 5         for i in 0..<costs.count {
 6             if i < costs.count / 2 {
 7                 minCost += costDiff[i][0]
 8             } else {
 9                 minCost += costDiff[i][1]
10             }
11         }
12         return minCost
13     }
14 }

20msblog

 1 class Solution {
 2     func twoCitySchedCost(_ costs: [[Int]]) -> Int {           
 3         let costs = costs.sorted { (a, b) in
 4             return abs(a[0] - a[1]) > abs(b[0] - b[1])
 5         }
 6         let N = costs.count / 2
 7         var c1 = 0, c2 = 0, ans = 0
 8         for i in 0..<2*N {
 9             if ((costs[i][0] < costs[i][1] && c1 < N) || c2 == N) {
10                 ans += costs[i][0]
11                 c1 += 1
12             }
13             else {
14                 ans += costs[i][1]
15                 c2 += 1
16             }
17         }
18         return ans
19 
20     }
21 }

24ms

 1 class Solution {
 2     func twoCitySchedCost(_ costs: [[Int]]) -> Int {
 3         
 4         var count = 0
 5         var deltaAtoB = [Int]()
 6         var deltaBtoA = [Int]()
 7         var result = 0
 8         for cost in costs {
 9             if cost[0] <= cost[1] {
10                 count += 1
11                 result += cost[0]
12                 deltaBtoA.append(cost[1] - cost[0])
13             } else {
14                 count -= 1
15                 result += cost[1]
16                 deltaAtoB.append(cost[0] - cost[1])
17             }
18         }
19 
20         if count == 0 {
21             return result
22         } else if count > 0 {
23             deltaBtoA.sort()
24             for i in 0..<count/2 {
25                 result += deltaBtoA[i]
26             }
27         } else {
28             deltaAtoB.sort()
29             for i in 0..<abs(count)/2 {
30                 result += deltaAtoB[i]
31             }
32         }
33         return result
34     }
35 }

28ms

 1 class Solution {
 2     func twoCitySchedCost(_ costs: [[Int]]) -> Int {
 3         var costDiff = costs.sorted(by: { $0[1] - $0[0]  > $1[1] - $1[0] })
 4         var minCost = 0
 5         for i in 0..<costs.count {
 6             if i < costs.count / 2 {
 7                 minCost += costDiff[i][0]
 8             } else {
 9                 minCost += costDiff[i][1]
10             }
11         }
12         return minCost
13     }
14 }

32ms

 1 class Solution {
 2     func twoCitySchedCost(_ costs: [[Int]]) -> Int {
 3         let N = costs.count / 2
 4         var dp = [[Int]]()
 5         
 6         for i in 0...N {
 7             let row = Array(repeating: 0, count: N+1)
 8             dp.append(row)
 9         }
10         
11         for i in 1...N {
12             dp[i][0] = dp[i-1][0] + costs[i-1][0]
13         }
14         
15         for j in 1...N {
16             dp[0][j] = dp[0][j-1] + costs[j-1][1]
17         }
18         
19         for i in 1...N {
20             for j in 1...N {
21                 dp[i][j] = min(dp[i-1][j] + costs[i+j-1][0], dp[i][j-1] + costs[i+j-1][1])
22             }
23         }
24         
25         return dp[N][N]
26     }
27 }

44ms

 1 class Solution {
 2     func twoCitySchedCost(_ costs: [[Int]]) -> Int {
 3         var costsrt = costs.sorted(by: {return abs($0[0]-$0[1]) >= abs($1[0]-$1[1])})
 4         
 5         var N = costs.count / 2
 6         var A = 0
 7         var B = 0
 8         var ac = 0
 9         var bc = 0
10         
11         for p in costsrt {
12             if (p[0] > p[1] && bc < N) || ac == N {
13                 B += p[1]
14                 bc += 1
15                 print("B:", p[1])
16             } else {
17                 A += p[0]
18                 ac += 1
19                 print("A:", p[0])
20             }
21         }
22         
23         return A+B
24     }
25 }
相關文章
相關標籤/搜索