Problem
You are given two 0-indexed integer permutations A
and B
of length n
.
A prefix common array of A
and B
is an array C
such that C[i]
is equal to the count of numbers that are present at or before the index i
in both A
and B
.
Return the prefix common array of A
and B
.
A sequence of n
integers is called a permutation if it contains all integers from 1
to n
exactly once.
https://leetcode.com/problems/find-the-prefix-common-array-of-two-arrays/
Example 1:
Input:
A = [1,3,2,4], B = [3,1,2,4]
Output:[0,2,3,4]
Explanation: Ati = 0
: no number is common, soC[0] = 0
.
Ati = 1
: 1 and 3 are common in A and B, soC[1] = 2
.
Ati = 2
: 1, 2, and 3 are common in A and B, soC[2] = 3
.
Ati = 3
: 1, 2, 3, and 4 are common in A and B, soC[3] = 4
.
Example 2:
Input:
A = [2,3,1], B = [3,1,2]
Output:[0,1,3]
Explanation: Ati = 0
: no number is common, soC[0] = 0
.
Ati = 1
: only 3 is common in A and B, soC[1] = 1
.
Ati = 2
: 1, 2, and 3 are common in A and B, soC[2] = 3
.
Constraints:
1 <= A.length == B.length == n <= 50
1 <= A[i], B[i] <= n
It is guaranteed that A and B are both a permutation of n integers.
Test Cases
1 | class Solution: |
1 | import pytest |
Thoughts
因为 A 和 B 都是 1 到 n 的排列,所以 1 到 n 的每一个数字在 A 和 B 中都分别刚好有且只有一次,A 和 B 一起看的话则是刚好有且只有两次。
从左到右同时遍历 A 和 B,对见到的数字计数,如果计数值为 2 说明此数字在 A 和 B 的前缀子数组中都出现过。
时间复杂度 O(n)
,空间复杂度 O(n)
。
Code
1 | class Solution: |