热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

数据结构系列之单链表实现一个简单的LRU算法

更多文章,欢迎关注微信公众号:深夜程猿在上一篇文章简单聊聊了LRU算法理论篇,这里就和大家使用单链表实现一个简单的LRU算法。其它类型的实

更多文章,欢迎关注微信公众号:深夜程猿

在上一篇文章简单聊聊了LRU算法理论篇,这里就和大家使用单链表实现一个简单的LRU算法。其它类型的实现一样的思路,只不过是处理的复杂程度不一样而已。

Node.java:存储数据的结点

package lru;/*** @author wu* @since 2019/4/2*/
public class Node {private V data;private K key;/*** 指针,指向下一节点*/private Node next;public V getData() {return data;}public void setData(V data) {this.data = data;}public Node getNext() {return next;}public void setNext(Node next) {this.next = next;}public K getKey() {return key;}public void setKey(K key) {this.key = key;}
}

LinkedLru.java:LRU实现

package lru;/*** @author wu* @since 2019/4/2*/
public class LinkedLru {private Node root;private int maxCapacity;private int defaultCapacity &#61; 10;public LinkedLru(int maxCapacity) {if (maxCapacity <&#61; 0) {throw new IllegalArgumentException("maxCapacity should not less than 0");}this.maxCapacity &#61; maxCapacity;}public int getMaxCapacity() {return maxCapacity;}public LinkedLru() {this.maxCapacity &#61; defaultCapacity;}public Node get(K key) {if (key &#61;&#61; null) {throw new IllegalArgumentException("key should not be null");}if (root &#61;&#61; null) {return null;}Node temp &#61; root;while (temp !&#61; null) {if (key.equals(temp.getKey())) {Node node &#61; new Node<>();node.setData(temp.getData());node.setKey(temp.getKey());return node;}temp &#61; temp.getNext();}return null;}public boolean add(Node data) {if (data &#61;&#61; null) {throw new IllegalArgumentException("can not cache null");}if (root &#61;&#61; null) {root &#61; data;return true;} else {Node prev &#61; root;Node next &#61; root.getNext();Node header &#61; root;Node cursor;int index &#61; 1;while (true) {index&#43;&#43;;cursor &#61; prev;if (index >&#61; getMaxCapacity()) {// 设置data为头部结点data.setNext(header);root &#61; data;// 缓存达到最大值&#xff0c;淘汰数据&#xff0c;此时prev就是尾部结点cursor.setNext(null);break;}if (next &#61;&#61; null) {// 容量没有达到最大&#xff0c;已到缓存尾部&#xff0c;并且数据还没有缓存过data.setNext(header);root &#61; data;cursor.setNext(null);break;}if (next.getKey() &#61;&#61; data.getKey()) {// 数据存在&#xff0c;交换指针&#xff0c;数据放在首部data.setNext(header);prev.setNext(next.getNext());root &#61; data;break;}prev &#61; next;next &#61; next.getNext();}}return true;}public Node getRoot() {return root;}
}

测试类&#xff1a;

package lru;import com.alibaba.fastjson.JSON;/*** &#64;author wu* &#64;since 2019/4/3*/
public class Test {public static void main(String[] args) {LinkedLru cache &#61; new LinkedLru<>(10);int pos &#61; 0;while (pos <100) {pos&#43;&#43;;Node node &#61; new Node();node.setKey("key:" &#43; pos);node.setData("data:" &#43; pos);cache.add(node);}System.out.println(JSON.toJSONString(cache.getRoot()));System.out.println(JSON.toJSONString(cache.get("key:10")));System.out.println(JSON.toJSONString(cache.get("key:100")));}}

输出&#xff1a;

{"data":"data:100","key":"key:100","next":{"data":"data:99","key":"key:99","next":{"data":"data:98","key":"key:98","next":{"data":"data:97","key":"key:97","next":{"data":"data:96","key":"key:96","next":{"data":"data:95","key":"key:95","next":{"data":"data:94","key":"key:94","next":{"data":"data:93","key":"key:93","next":{"data":"data:92","key":"key:92","next":{"data":"data:91","key":"key:91"}}}}}}}}}}
null
{"data":"data:100","key":"key:100"}

系列文章

数据结构小白系列之数据结构概述

数据结构系列之LRU算法理论篇



推荐阅读
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • Java中包装类的设计原因以及操作方法
    本文主要介绍了Java中设计包装类的原因以及操作方法。在Java中,除了对象类型,还有八大基本类型,为了将基本类型转换成对象,Java引入了包装类。文章通过介绍包装类的定义和实现,解答了为什么需要包装类的问题,并提供了简单易用的操作方法。通过本文的学习,读者可以更好地理解和应用Java中的包装类。 ... [详细]
  • Java自带的观察者模式及实现方法详解
    本文介绍了Java自带的观察者模式,包括Observer和Observable对象的定义和使用方法。通过添加观察者和设置内部标志位,当被观察者中的事件发生变化时,通知观察者对象并执行相应的操作。实现观察者模式非常简单,只需继承Observable类和实现Observer接口即可。详情请参考Java官方api文档。 ... [详细]
  • 本文讨论了如何优化解决hdu 1003 java题目的动态规划方法,通过分析加法规则和最大和的性质,提出了一种优化的思路。具体方法是,当从1加到n为负时,即sum(1,n)sum(n,s),可以继续加法计算。同时,还考虑了两种特殊情况:都是负数的情况和有0的情况。最后,通过使用Scanner类来获取输入数据。 ... [详细]
  • Mac OS 升级到11.2.2 Eclipse打不开了,报错Failed to create the Java Virtual Machine
    本文介绍了在Mac OS升级到11.2.2版本后,使用Eclipse打开时出现报错Failed to create the Java Virtual Machine的问题,并提供了解决方法。 ... [详细]
  • 本文介绍了如何在给定的有序字符序列中插入新字符,并保持序列的有序性。通过示例代码演示了插入过程,以及插入后的字符序列。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • JVM 学习总结(三)——对象存活判定算法的两种实现
    本文介绍了垃圾收集器在回收堆内存前确定对象存活的两种算法:引用计数算法和可达性分析算法。引用计数算法通过计数器判定对象是否存活,虽然简单高效,但无法解决循环引用的问题;可达性分析算法通过判断对象是否可达来确定存活对象,是主流的Java虚拟机内存管理算法。 ... [详细]
  • Python正则表达式学习记录及常用方法
    本文记录了学习Python正则表达式的过程,介绍了re模块的常用方法re.search,并解释了rawstring的作用。正则表达式是一种方便检查字符串匹配模式的工具,通过本文的学习可以掌握Python中使用正则表达式的基本方法。 ... [详细]
  • 关键词:Golang, Cookie, 跟踪位置, net/http/cookiejar, package main, golang.org/x/net/publicsuffix, io/ioutil, log, net/http, net/http/cookiejar ... [详细]
  • 在重复造轮子的情况下用ProxyServlet反向代理来减少工作量
    像不少公司内部不同团队都会自己研发自己工具产品,当各个产品逐渐成熟,到达了一定的发展瓶颈,同时每个产品都有着自己的入口,用户 ... [详细]
  • [大整数乘法] java代码实现
    本文介绍了使用java代码实现大整数乘法的过程,同时也涉及到大整数加法和大整数减法的计算方法。通过分治算法来提高计算效率,并对算法的时间复杂度进行了研究。详细代码实现请参考文章链接。 ... [详细]
  • Go Cobra命令行工具入门教程
    本文介绍了Go语言实现的命令行工具Cobra的基本概念、安装方法和入门实践。Cobra被广泛应用于各种项目中,如Kubernetes、Hugo和Github CLI等。通过使用Cobra,我们可以快速创建命令行工具,适用于写测试脚本和各种服务的Admin CLI。文章还通过一个简单的demo演示了Cobra的使用方法。 ... [详细]
  • 本文介绍了如何使用Express App提供静态文件,同时提到了一些不需要使用的文件,如package.json和/.ssh/known_hosts,并解释了为什么app.get('*')无法捕获所有请求以及为什么app.use(express.static(__dirname))可能会提供不需要的文件。 ... [详细]
author-avatar
做普通的自我
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有