[Swift-2019力扣杯春季决赛]4. 有效子数组的数目
发布时间:2020-12-14 04:51:23 所属栏目:百科 来源:网络整理
导读:给定一个整数数组? A ,返回满足下面条件的?非空、连续?子数组的数目: 子数组中,最左侧的元素不大于其他元素。 示例 1: 输入:[1,4,2,5,3]输出:11解释:有 11 个有效子数组,分别是:[1],[4],[2],[5],[3],[1,4],[2,5],2],3],3] 。 示例 2: 输入:[3,1]
给定一个整数数组? 子数组中,最左侧的元素不大于其他元素。 示例 1: 输入:[1,4,2,5,3] 输出:11 解释:有 11 个有效子数组,分别是:[1],[4],[2],[5],[3],[1,4],[2,5],2],3],3] 。 示例 2: 输入:[3,1] 输出:3 解释:有 3 个有效子数组,分别是:[3],[1] 。 示例 3: 输入:[2,2] 输出:6 解释:有 6 个有效子数组,分别为是:[2],2] 。 提示:
848 ms 1 class Solution { 2 var ne:[Int] = [Int](repeating:0,count:50005) 3 var st:[Int] = [Int](repeating:0,count:50005) 4 var t:Int = 0 5 func validSubarrays(_ nums: [Int]) -> Int { 6 var n:Int = nums.count 7 var ans:Int = 0 8 st[0] = n 9 for i in stride(from:(n - 1),through:0,by:-1) 10 { 11 while((t != 0) && nums[st[t]] >= nums[i]) 12 { 13 t -= 1 14 } 15 ne[i] = st[t] 16 t += 1 17 st[t] = i 18 ans += ne[i] - i 19 } 20 return ans 21 } 22 } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |