package main
import(
"fmt"
)
type Node struct {
Key string
Val string
Pre *Node
Next *Node
}
type DLinkedList struct {
Head *Node
Tail *Node
}
func (self *DLinkedList) IsEmpty() bool {
if self.Head == nil && self.Tail == nil {
return true
} else {
return false
}
}
func (self *DLinkedList) RemoveLast() {
if self.Tail != nil {
self.Remove(self.Tail)
}
}
func (self *DLinkedList) Remove(n *Node){
if self.Tail == self.Head {
self.Head = nil
self.Tail = nil
return
}
if n == self.Head {
n.Next.Pre = nil
self.Head = n.Next
return
}
if n == self.Tail {
n.Pre.Next = nil
self.Tail = n.Pre
return
}
n.Pre.Next = n.Next
n.Next.Pre = n.Pre
}
func (self *DLinkedList) AddFirst(n *Node) {
if self.Head == nil {
self.Head = n
self.Tail = n
n.Pre = nil
n.Next = nil
return
}
n.Next = self.Head
self.Head.Pre = n
self.Head = n
n.Pre = nil
}
type LRUCache struct {
Cap int
Size int
HashMap map[string]*Node
Cache *DLinkedList
}
func (self *LRUCache) Get(k string) string {
if node,ok := self.HashMap[k]; ok {
self.Cache.Remove(node)
self.Cache.AddFirst(node)
return node.Val
} else {
return ""
}
}
func (self *LRUCache) Set(k,val string ) {
if node,ok := self.HashMap[k];ok {
self.Cache.Remove(node)
node.Val = val
self.Cache.AddFirst(node)
} else {
n := &Node{Key:k,Val:val}
self.HashMap[k] = n
self.Cache.AddFirst(n)
self.Size = self.Size + 1
if self.Size > self.Cap {
self.Size = self.Size - 1
delete(self.HashMap,self.Cache.Tail.Key)
self.Cache.RemoveLast()
}
}
}
func main() {
cache := new(LRUCache)
cache.Cap = 3
cache.HashMap = make(map[string]*Node,0)
cache.Cache = new(DLinkedList)
cache.Set("allen","value")
cache.Set("a","value")
cache.Set("b","value")
cache.Set("c","value")
test := cache.Get("allen")
fmt.Println(test)
fmt.Println(cache.HashMap)
fmt.Println(cache.Cache)
fmt.Println(cache.Size)
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
密码学原理与实践
[加]Douglas R.Stinson / 冯登国 / 电子工业出版社 / 2009年 / 55.00元
冯登国(FENG Dengguo,1965.5~), 现为中国科学院软件所研究员、博士生导师,信息安全国家重点实验室主任,国家计算机网络入侵防范中心主任,国家信息化专家咨询委员会委员。目前主要从事信息与网络安全方面的研究与开发工作。一起来看看 《密码学原理与实践》 这本书的介绍吧!