// Copyright 2018 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 set import "math/bits" // Int32s represents a set of integers within the range of 0..31. type Int32s uint32 func (bs *Int32s) Len() int { return bits.OnesCount32(uint32(*bs)) } func (bs *Int32s) Has(n uint64) bool { return uint32(*bs)&(uint32(1)< 0 } func (bs *Int32s) Set(n uint64) { *(*uint32)(bs) |= uint32(1) << n } func (bs *Int32s) Clear(n uint64) { *(*uint32)(bs) &^= uint32(1) << n } // Int64s represents a set of integers within the range of 0..63. type Int64s uint64 func (bs *Int64s) Len() int { return bits.OnesCount64(uint64(*bs)) } func (bs *Int64s) Has(n uint64) bool { return uint64(*bs)&(uint64(1)< 0 } func (bs *Int64s) Set(n uint64) { *(*uint64)(bs) |= uint64(1) << n } func (bs *Int64s) Clear(n uint64) { *(*uint64)(bs) &^= uint64(1) << n } // Ints represents a set of integers within the range of 0..math.MaxUint64. type Ints struct { lo Int64s hi map[uint64]struct{} } func (bs *Ints) Len() int { return bs.lo.Len() + len(bs.hi) } func (bs *Ints) Has(n uint64) bool { if n < 64 { return bs.lo.Has(n) } _, ok := bs.hi[n] return ok } func (bs *Ints) Set(n uint64) { if n < 64 { bs.lo.Set(n) return } if bs.hi == nil { bs.hi = make(map[uint64]struct{}) } bs.hi[n] = struct{}{} } func (bs *Ints) Clear(n uint64) { if n < 64 { bs.lo.Clear(n) return } delete(bs.hi, n) }