2021-03-18 05:10:20 +00:00
|
|
|
package main
|
|
|
|
|
|
|
|
type Prec struct {
|
2022-02-21 03:32:53 +00:00
|
|
|
Sets []map[string]int
|
|
|
|
NameToSet map[string]int
|
2021-03-18 05:10:20 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func NewPrec() *Prec {
|
2022-02-21 03:32:53 +00:00
|
|
|
return &Prec{NameToSet: make(map[string]int)}
|
2021-03-18 05:10:20 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (p *Prec) AddSet(precs ...string) {
|
2022-02-21 03:32:53 +00:00
|
|
|
set := make(map[string]int)
|
|
|
|
setIndex, i := len(p.Sets), 0
|
|
|
|
for _, prec := range precs {
|
|
|
|
set[prec] = i
|
|
|
|
p.NameToSet[prec] = setIndex
|
|
|
|
i++
|
|
|
|
}
|
|
|
|
p.Sets = append(p.Sets, set)
|
2021-03-18 05:10:20 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (p *Prec) InAnySet(name string) bool {
|
2022-02-21 03:32:53 +00:00
|
|
|
_, ok := p.NameToSet[name]
|
|
|
|
return ok
|
2021-03-18 05:10:20 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (p *Prec) InSameSet(n, n2 string) bool {
|
2022-02-21 03:32:53 +00:00
|
|
|
ok, ok2 := p.InAnySet(n), p.InAnySet(n2)
|
|
|
|
if !ok || !ok2 {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
set1, set2 := p.NameToSet[n], p.NameToSet[n2]
|
|
|
|
return set1 == set2
|
2021-03-18 05:10:20 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (p *Prec) GreaterThan(greater, lesser string) bool {
|
2022-02-21 03:32:53 +00:00
|
|
|
if !p.InSameSet(greater, lesser) {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
set := p.Sets[p.NameToSet[greater]]
|
|
|
|
return set[greater] > set[lesser]
|
2021-03-18 05:10:20 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (p *Prec) LessThanItem(greater string) (l []string) {
|
2022-02-21 03:32:53 +00:00
|
|
|
if len(p.Sets) == 0 {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
setIndex := p.NameToSet[greater]
|
|
|
|
set := p.Sets[setIndex]
|
|
|
|
ref := set[greater]
|
|
|
|
for name, value := range set {
|
|
|
|
if value < ref {
|
|
|
|
l = append(l, name)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return l
|
2021-03-18 05:10:20 +00:00
|
|
|
}
|