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
|
// Copyright 2021 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package a
type Pair[L, R any] struct {
L L
R R
}
func Two[L, R any](l L, r R) Pair[L, R] {
return Pair[L, R]{L: l, R: r}
}
type Map[K, V any] interface {
Put(K, V)
Len() int
Iterate(func(Pair[K, V]) bool)
}
type HashMap[K comparable, V any] struct {
m map[K]V
}
func NewHashMap[K comparable, V any](capacity int) HashMap[K, V] {
var m map[K]V
if capacity >= 1 {
m = make(map[K]V, capacity)
} else {
m = map[K]V{}
}
return HashMap[K, V]{m: m}
}
func (m HashMap[K, V]) Put(k K, v V) {
m.m[k] = v
}
func (m HashMap[K, V]) Len() int {
return len(m.m)
}
func (m HashMap[K, V]) Iterate(cb func(Pair[K, V]) bool) {
for k, v := range m.m {
if !cb(Two(k, v)) {
return
}
}
}
|