forked from tunabay/go-bitarray
-
Notifications
You must be signed in to change notification settings - Fork 0
/
bitarray_search_example_test.go
63 lines (45 loc) · 1.3 KB
/
bitarray_search_example_test.go
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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
// Copyright (c) 2021 Hirotsuna Mizuno. All rights reserved.
// Use of this source code is governed by the MIT license that can be found in
// the LICENSE file.
package bitarray_test
import (
"fmt"
"github.com/tunabay/go-bitarray"
)
func ExampleBitArray_HasPrefix() {
ba := bitarray.MustParse("1010-1111 0000-1111 10")
fmt.Println(ba.HasPrefix(bitarray.MustParse("10101")))
fmt.Println(ba.HasPrefix(bitarray.MustParse("111")))
// Output:
// true
// false
}
func ExampleBitArray_HasSuffix() {
ba := bitarray.MustParse("1010-1111 0000-1111 10")
fmt.Println(ba.HasSuffix(bitarray.MustParse("11110")))
fmt.Println(ba.HasSuffix(bitarray.MustParse("111")))
// Output:
// true
// false
}
func ExampleBitArray_Index() {
haystack := bitarray.MustParse("0010-1011 0001-0101 0101-0111 111")
needle := bitarray.MustParse("1010")
fmt.Println(haystack.Index(needle))
// Output:
// 2
}
func ExampleBitArray_LastIndex() {
haystack := bitarray.MustParse("0010-1011 0001-0101 0101-0111 111")
needle := bitarray.MustParse("1010")
fmt.Println(haystack.LastIndex(needle))
// Output:
// 17
}
func ExampleBitArray_AllIndex() {
haystack := bitarray.MustParse("0010-1011 0001-0101 0101-0111 111")
needle := bitarray.MustParse("1010")
fmt.Println(haystack.AllIndex(needle))
// Output:
// [2 11 13 15 17]
}