在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ Given a list of Return the number of pairs Example 1: Input: dominoes = [[1,2],[2,1],[3,4],[5,6]] Output: 1 Constraints:
给你一个由一些多米诺骨牌组成的列表 如果其中某一张多米诺骨牌可以通过旋转 形式上, 在 示例: 输入:dominoes = [[1,2],[2,1],[3,4],[5,6]] 输出:1 提示:
192ms
1 class Solution { 2 func dominoHash(_ dom:[Int]) -> Int { 3 if dom[0] > dom[1] { 4 return 100*dom[1] + dom[0] 5 } 6 return 100*dom[0] + dom[1] 7 } 8 9 func numEquivDominoPairs(_ dominoes: [[Int]]) -> Int { 10 var result = 0 11 var counts = [Int : Int]() 12 13 for d in dominoes { 14 let h = dominoHash(d) 15 if let count = counts[h] { 16 result += count 17 counts[h] = count + 1 18 } else { 19 counts[h] = 1 20 } 21 } 22 return result 23 } 24 } 196ms 1 sample 196 ms submission 2 class Solution { 3 func numEquivDominoPairs(_ dominoes: [[Int]]) -> Int { 4 var originals = [Int]() 5 6 dominoes.forEach { (domino) in 7 originals.append(10*min(domino[0], domino[1]) + max(domino[0], domino[1])) 8 } 9 10 var counts: [Int: Int] = [:] 11 originals.forEach { counts[$0, default: 0] += 1 } 12 13 var count = 0 14 counts.forEach { count = count + ( $1 * ($1 - 1)/2 ) } 15 16 return count 17 } 18 } 200ms 1 class Solution { 2 func numEquivDominoPairs(_ dominoes: [[Int]]) -> Int { 3 let dominoes = dominoes.map { dom -> Int in 4 if dom[0] <= dom[1] { 5 return dom[0] * 10 + dom[1] 6 } else { 7 return dom[1] * 10 + dom[0] 8 } 9 } 10 var counts = [Int: Int]() 11 var res = 0 12 for num in dominoes { 13 res += (counts[num] ?? 0) 14 counts[num, default: 0] += 1 15 } 16 return res 17 } 18 } Runtime: 224 ms Memory Usage: 23.9 MB
1 class Solution { 2 func numEquivDominoPairs(_ dominoes: [[Int]]) -> Int { 3 var dominoes = dominoes 4 var freq:[[Int]:Int] = [[Int]:Int]() 5 var total:Int = 0 6 for i in 0..<dominoes.count 7 { 8 if dominoes[i][0] > dominoes[i][1] 9 { 10 dominoes[i].swapAt(0,1) 11 } 12 total += freq[[dominoes[i][0], dominoes[i][1]],default:0] 13 freq[[dominoes[i][0], dominoes[i][1]],default:0] += 1 14 } 15 return total 16 } 17 }
|
请发表评论