Description
You are given two arrays, one shorter (with all distinct elements) and one longer. Find the shortest subarray in the longer array that contains all the elements in the shorter array. The items can appear in any order.
Return the indexes of the leftmost and the rightmost elements of the array. If there are more than one answer, return the one that has the smallest left index. If there is no answer, return an empty array.
Example 1:
Input:
big = [7,5,9,0,2,1,3,5,7,9,1 ,1,5,8,8,9,7]
small = [1,5,9]
Output: [7,10]
Example 2:
Input:
big = [1,2,3]
small = [4]
Output: []
Note:
big.length <= 100000
1 <= small.length <= 100000
Solutions
Solution 1
Python3 Java C++ Go TypeScript Swift
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18 class Solution :
def shortestSeq ( self , big : List [ int ], small : List [ int ]) -> List [ int ]:
need = Counter ( small )
window = Counter ()
cnt , j , k , mi = len ( small ), 0 , - 1 , inf
for i , x in enumerate ( big ):
window [ x ] += 1
if need [ x ] >= window [ x ]:
cnt -= 1
while cnt == 0 :
if i - j + 1 < mi :
mi = i - j + 1
k = j
if need [ big [ j ]] >= window [ big [ j ]]:
cnt += 1
window [ big [ j ]] -= 1
j += 1
return [] if k < 0 else [ k , k + mi - 1 ]
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28 class Solution {
public int [] shortestSeq ( int [] big , int [] small ) {
int cnt = small . length ;
Map < Integer , Integer > need = new HashMap <> ( cnt );
Map < Integer , Integer > window = new HashMap <> ( cnt );
for ( int x : small ) {
need . put ( x , 1 );
}
int k = - 1 , mi = 1 << 30 ;
for ( int i = 0 , j = 0 ; i < big . length ; ++ i ) {
window . merge ( big [ i ] , 1 , Integer :: sum );
if ( need . getOrDefault ( big [ i ] , 0 ) >= window . get ( big [ i ] )) {
-- cnt ;
}
while ( cnt == 0 ) {
if ( i - j + 1 < mi ) {
mi = i - j + 1 ;
k = j ;
}
if ( need . getOrDefault ( big [ j ] , 0 ) >= window . get ( big [ j ] )) {
++ cnt ;
}
window . merge ( big [ j ++] , - 1 , Integer :: sum );
}
}
return k < 0 ? new int [ 0 ] : new int [] { k , k + mi - 1 };
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32 class Solution {
public :
vector < int > shortestSeq ( vector < int >& big , vector < int >& small ) {
int cnt = small . size ();
unordered_map < int , int > need ;
unordered_map < int , int > window ;
for ( int x : small ) {
need [ x ] = 1 ;
}
int k = -1 , mi = 1 << 30 ;
for ( int i = 0 , j = 0 ; i < big . size (); ++ i ) {
window [ big [ i ]] ++ ;
if ( need [ big [ i ]] >= window [ big [ i ]]) {
-- cnt ;
}
while ( cnt == 0 ) {
if ( i - j + 1 < mi ) {
mi = i - j + 1 ;
k = j ;
}
if ( need [ big [ j ]] >= window [ big [ j ]]) {
++ cnt ;
}
window [ big [ j ++ ]] -- ;
}
}
if ( k < 0 ) {
return {};
}
return { k , k + mi - 1 };
}
};
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30 func shortestSeq ( big [] int , small [] int ) [] int {
cnt := len ( small )
need := map [ int ] int {}
window := map [ int ] int {}
for _ , x := range small {
need [ x ] = 1
}
j , k , mi := 0 , - 1 , 1 << 30
for i , x := range big {
window [ x ] ++
if need [ x ] >= window [ x ] {
cnt --
}
for cnt == 0 {
if t := i - j + 1 ; t < mi {
mi = t
k = j
}
if need [ big [ j ]] >= window [ big [ j ]] {
cnt ++
}
window [ big [ j ]] --
j ++
}
}
if k < 0 {
return [] int {}
}
return [] int { k , k + mi - 1 }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28 function shortestSeq ( big : number [], small : number []) : number [] {
let cnt = small . length ;
const need : Map < number , number > = new Map ();
const window : Map < number , number > = new Map ();
for ( const x of small ) {
need . set ( x , 1 );
}
let k = - 1 ;
let mi = 1 << 30 ;
for ( let i = 0 , j = 0 ; i < big . length ; ++ i ) {
window . set ( big [ i ], ( window . get ( big [ i ]) ?? 0 ) + 1 );
if (( need . get ( big [ i ]) ?? 0 ) >= window . get ( big [ i ]) ! ) {
-- cnt ;
}
while ( cnt === 0 ) {
if ( i - j + 1 < mi ) {
mi = i - j + 1 ;
k = j ;
}
if (( need . get ( big [ j ]) ?? 0 ) >= window . get ( big [ j ]) ! ) {
++ cnt ;
}
window . set ( big [ j ], window . get ( big [ j ]) ! - 1 );
++ j ;
}
}
return k < 0 ? [] : [ k , k + mi - 1 ];
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41 class Solution {
func shortestSeq ( _ big : [ Int ], _ small : [ Int ]) -> [ Int ] {
let needCount = small . count
var need = [ Int : Int ]()
var window = [ Int : Int ]()
small . forEach { need [ $0 , default : 0 ] += 1 }
var count = needCount
var minLength = Int . max
var result = ( - 1 , - 1 )
var left = 0
for right in 0. .< big . count {
let element = big [ right ]
if need [ element ] != nil {
window [ element , default : 0 ] += 1
if window [ element ] ! <= need [ element ] ! {
count -= 1
}
}
while count == 0 {
if right - left + 1 < minLength {
minLength = right - left + 1
result = ( left , right )
}
let leftElement = big [ left ]
if need [ leftElement ] != nil {
window [ leftElement ] ! -= 1
if window [ leftElement ] ! < need [ leftElement ] ! {
count += 1
}
}
left += 1
}
}
return result . 0 == - 1 ? [] : [ result . 0 , result . 1 ]
}
}
GitHub