blob: 63e599d9a18696840d7c9ca9db716470e0e59f07 [file] [log] [blame]
// 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
}
}
}