在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ Given a nested list of integers, return the sum of all integers in the list weighted by their depth. Each element is either an integer, or a list -- whose elements may also be integers or other lists. Example 1: Example 2: 给定一个嵌套的整数列表,返回列表中按深度加权的所有整数的和。 每个元素要么是一个整数,要么是一个列表——其元素也可以是整数或其他列表。 例1: 给定列表[[1,1],2,[1,1]],返回10。(深度2处4个1,深度1处1个2) 例2: 给定列表[1,[4,[6]]],返回27。(深度1处1个1,深度2处1个4,深度3处1个6;1+4*2+6*3=27) Solution: 1 class Solution { 2 func depthSum(_ nestedList:inout [NestedInteger]) -> Int { 3 retrurn helper(&nestedList, 1) 4 } 5 6 func helper(_ nl:inout [NestedInteger],_ depth:Int) -> Int 7 { 8 var res:Int = 0 9 for a in nl 10 { 11 if let num:Int = Int(a) 12 { 13 res += (num * depth) 14 } 15 else 16 { 17 var list = a.getList() 18 res += helper(&list, depth + 1) 19 } 20 } 21 return res 22 } 23 }
|
请发表评论