2024-07-06:用go语言,给定一个从0开始的长度为n的整数数组nums和一个从0开始的长度为m的整数数组pattern,其中pattern数组的元素只包含-1、0和1。
我们定义“匹配”的子数组,对于一个大小为m+1的子数组nums[i..j],如果对于pattern数组中的每个元素pattern[k]都满足以下条件:
1.如果pattern[k]为1,则nums[i+k+1]必须大于nums[i+k];
2.如果pattern[k]为0,则nums[i+k+1]必须等于nums[i+k];
3.如果pattern[k]为-1,则nums[i+k+1]必须小于nums[i+k]。
要求计算有多少个子数组符合以上匹配条件。
输入:nums = [1,2,3,4,5,6], pattern = [1,1]。
输出:4。
解释:模式 [1,1] 说明我们要找的子数组是长度为 3 且严格上升的。在数组 nums 中,子数组 [1,2,3] ,[2,3,4] ,[3,4,5] 和 [4,5,6] 都匹配这个模式。
所以 nums 中总共有 4 个子数组匹配这个模式。
相似问题