You cannot select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
	
	
		
			59 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Go
		
	
		
		
			
		
	
	
			59 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Go
		
	
| 
											2 years ago
										 | // 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 provides simple set data structures for uint64s.
 | ||
|  | package set | ||
|  | 
 | ||
|  | import "math/bits" | ||
|  | 
 | ||
|  | // 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)<<n) > 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) | ||
|  | } |