當前位置: 首頁>>代碼示例>>Golang>>正文


Golang Key.Less方法代碼示例

本文整理匯總了Golang中tree.Key.Less方法的典型用法代碼示例。如果您正苦於以下問題:Golang Key.Less方法的具體用法?Golang Key.Less怎麽用?Golang Key.Less使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在tree.Key的用法示例。


在下文中一共展示了Key.Less方法的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。

示例1: Find

func (b *Branch) Find(key tree.Key) (interface{}, bool) {
	i := 0
	for ; i < b.numKeys; i++ {
		if key.Less(b.key[i]) {
			break
		}
	}
	return b.twig[i].Find(key)
}
開發者ID:taysom,項目名稱:va,代碼行數:9,代碼來源:merge.go

示例2: Delete

func (b *Branch) Delete(key tree.Key) {
	i := 0
	for ; i < b.numKeys; i++ {
		if key.Less(b.key[i]) {
			break
		}
	}
	b.twig[i].Delete(key)
}
開發者ID:taysom,項目名稱:va,代碼行數:9,代碼來源:bplus.go

示例3: Check

func (t *Tree) Check(key tree.Key) tree.Key {
	var next tree.Key
	for _, r := range t.rec {
		next = r.Key
		if next.Less(key) {
			log.Fatal("keys out of order")
		}
		key = next
	}
	return key
}
開發者ID:taysom,項目名稱:va,代碼行數:11,代碼來源:bsearch.go

示例4: Insert

func (l *Leaf) Insert(key tree.Key, value interface{}) {
	var i int
	for i = 0; i < l.numKeys; i++ {
		if key.Less(l.record[i].Key) {
			for j := l.numKeys; j > i; j-- {
				l.record[j] = l.record[j-1]
			}
			break
		}
	}
	l.numKeys++
	l.record[i] = tree.Record{key, value}
}
開發者ID:taysom,項目名稱:va,代碼行數:13,代碼來源:merge.go

示例5: Find

func (t *Tree) Find(key tree.Key) (interface{}, bool) {
	for node := t.root; node != nil; {
		switch {
		case node.rec.Key.Less(key):
			node = node.right
		case key.Less(node.rec.Key):
			node = node.left
		default:
			return node.rec.Value, true
		}
	}
	return nil, false
}
開發者ID:taysom,項目名稱:va,代碼行數:13,代碼來源:binary.go

示例6: Succ

func (b *Branch) Succ(key tree.Key) (tree.Record, bool) {
	i := 0
	for ; i < b.numKeys; i++ {
		if key.Less(b.key[i]) {
			break
		}
	}
	for ; i < b.numKeys; i++ {
		rec, found := b.twig[i].Succ(key)
		if found {
			return rec, found
		}
	}
	return b.twig[i].Succ(key)
}
開發者ID:taysom,項目名稱:va,代碼行數:15,代碼來源:merge.go

示例7: bsearch

func (t *Tree) bsearch(key tree.Key) (int, bool) {
	left := 0
	right := len(t.rec) - 1
	for left <= right {
		middle := (left + right) / 2
		if key.Less(t.rec[middle].Key) {
			right = middle - 1
		} else if key == t.rec[middle].Key {
			return middle, true
		} else {
			left = middle + 1
		}
	}
	return left, false
}
開發者ID:taysom,項目名稱:va,代碼行數:15,代碼來源:bsearch.go

示例8: Succ

func (t *Tree) Succ(key tree.Key) (tree.Record, bool) {
	var next *Node
	for node := t.root; node != nil; {
		if node.rec.Key.Less(key) {
			node = node.right
		} else if key.Less(node.rec.Key) {
			next = node
			node = node.left
		} else {
			if node.right != nil {
				for next = node.right; next.left != nil; next = next.left {
				}
			}
			break
		}
	}
	if next == nil {
		return tree.Record{}, false
	}
	return next.rec, true
}
開發者ID:taysom,項目名稱:va,代碼行數:21,代碼來源:binary.go

示例9: Insert

func (b *Branch) Insert(key tree.Key, value interface{}) {
	var i int
	for i = 0; i < b.numKeys; i++ {
		if key.Less(b.key[i]) {
			break
		}
	}
	twig := b.twig[i]
	if twig.isFull() {
		sibling, newKey := twig.split()
		for j := b.numKeys; j > i; j-- {
			b.key[j] = b.key[j-1]
			b.twig[j+1] = b.twig[j] // One more twig than keys
		}
		b.key[i] = newKey
		b.twig[i+1] = sibling
		b.numKeys++
		if newKey.Less(key) {
			twig = sibling
		}
	}
	twig.Insert(key, value)
}
開發者ID:taysom,項目名稱:va,代碼行數:23,代碼來源:bplus.go

示例10: Delete

func (t *Tree) Delete(key tree.Key) {
	np := &t.root
	for node := t.root; node != nil; node = *np {
		switch {
		case node.rec.Key.Less(key):
			np = &node.right
		case key.Less(node.rec.Key):
			np = &node.left
		default:
			switch {
			case node.left == nil:
				*np = node.right
			case node.right == nil:
				*np = node.left
			default:
				replacement := delRight(&node.left)
				replacement.left = node.left
				replacement.right = node.right
				*np = replacement
			}
			return
		}
	}
}
開發者ID:taysom,項目名稱:va,代碼行數:24,代碼來源:binary.go


注:本文中的tree.Key.Less方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。