1
0
mirror of https://gitee.com/coder-xiaomo/leetcode-problemset synced 2025-01-27 10:40:26 +08:00
Code Issues Projects Releases Wiki Activity GitHub Gitee
leetcode-problemset/leetcode-cn/problem (Chinese)/匹配模式数组的子数组数目 II [number-of-subarrays-that-match-a-pattern-ii].html

43 lines
2.3 KiB
HTML
Raw Normal View History

2024-02-19 15:29:53 +08:00
<p>给你一个下标从 <strong>0</strong>&nbsp;开始长度为 <code>n</code>&nbsp;的整数数组&nbsp;<code>nums</code>&nbsp;,和一个下标从 <code>0</code>&nbsp;开始长度为 <code>m</code>&nbsp;的整数数组&nbsp;<code>pattern</code>&nbsp;<code>pattern</code>&nbsp;数组只包含整数&nbsp;<code>-1</code>&nbsp;<code>0</code>&nbsp;&nbsp;<code>1</code>&nbsp;</p>
<p>大小为 <code>m + 1</code>&nbsp;<span data-keyword="subarray">子数组</span>&nbsp;<code>nums[i..j]</code>&nbsp;如果对于每个元素 <code>pattern[k]</code>&nbsp;都满足以下条件,那么我们说这个子数组匹配模式数组&nbsp;<code>pattern</code>&nbsp;</p>
<ul>
<li>如果 <code>pattern[k] == 1</code> ,那么 <code>nums[i + k + 1] &gt; nums[i + k]</code></li>
<li>如果&nbsp;<code>pattern[k] == 0</code>&nbsp;,那么&nbsp;<code>nums[i + k + 1] == nums[i + k]</code></li>
<li>如果&nbsp;<code>pattern[k] == -1</code>&nbsp;,那么&nbsp;<code>nums[i + k + 1] &lt; nums[i + k]</code></li>
</ul>
<p>请你返回匹配 <code>pattern</code>&nbsp;<code>nums</code>&nbsp;子数组的 <strong>数目</strong>&nbsp;</p>
<p>&nbsp;</p>
<p><strong class="example">示例 1</strong></p>
<pre>
<b>输入:</b>nums = [1,2,3,4,5,6], pattern = [1,1]
<b>输出:</b>4
<b>解释:</b>模式 [1,1] 说明我们要找的子数组是长度为 3 且严格上升的。在数组 nums 中,子数组 [1,2,3] [2,3,4] [3,4,5] 和 [4,5,6] 都匹配这个模式。
所以 nums 中总共有 4 个子数组匹配这个模式。
</pre>
<p><strong class="example">示例 2</strong></p>
<pre>
<b>输入:</b>nums = [1,4,4,1,3,5,5,3], pattern = [1,0,-1]
<b>输出:</b>2
<strong>解释:</strong>这里,模式数组 [1,0,-1] 说明我们需要找的子数组中,第一个元素小于第二个元素,第二个元素等于第三个元素,第三个元素大于第四个元素。在 nums 中,子数组 [1,4,4,1] 和 [3,5,5,3] 都匹配这个模式。
所以 nums 中总共有 2 个子数组匹配这个模式。
</pre>
<p>&nbsp;</p>
<p><strong>提示:</strong></p>
<ul>
<li><code>2 &lt;= n == nums.length &lt;= 10<sup>6</sup></code></li>
<li><code>1 &lt;= nums[i] &lt;= 10<sup>9</sup></code></li>
<li><code>1 &lt;= m == pattern.length &lt; n</code></li>
<li><code>-1 &lt;= pattern[i] &lt;= 1</code></li>
</ul>