java版本存储器管理LRU
2016-05-19 09:57
465 查看
import java.util.Scanner; class Node { protected Node next; //指针域 protected int data;//数据域 public Node( int data) { this. data = data; } //显示此节点 public void display() { System. out.print( data + " "); } } //单链表 public class shiyan2 { public Node first; // 定义一个头结点 private int pos = 0;// 节点的位置 public shiyan2() { this. first = null; } // 插入一个头节点 public void addFirstNode( int data) { Node node = new Node(data); node. next = first; first = node; } // 根据节点的data删除节点 public Node deleteByData( int data) { Node current = first; Node previous = first; //记住上一个节点 while (current. data != data) { if (current. next == null) { return null; } previous = current; current = current. next; } if(current == first) { first = first. next; } else { previous. next = current. next; } return current; } // 删除任意位置的节点 public Node deleteByPos( int index) { Node current = first; Node previous = first; while ( pos != index) { pos++; previous = current; current = current. next; } if(current == first) { first = first. next; } else { pos = 0; previous. next = current. next; } return current; } // 显示出所有的节点信息 public void displayAllNodes() { Node current = first; while (current != null) { current.display(); current = current. next; } System. out.println(); } // 根据数据查找节点信息 public int find( int data) { Node current = first; while (current. data != data) { if (current. next == null) return 0; current = current. next; } return 1; } public int getLength(){ int result = 0; Node current = first; while(null!=current){ result++; current = current.next; } return result; } } //测试类 class ceshi { public static void main(String[] args) { shiyan2 sy=new shiyan2(); Scanner in = new Scanner(System.in); System.out.println("请输入你要访问的次数:"); int n = in.nextInt(); int d=0; for(int i=0;i<n;i++){ System.out.println("请你输入你要访问的页面:"); int m = in.nextInt(); if(i==0){ sy.addFirstNode(m); }else{ if(sy.find(m)==0){ sy.addFirstNode(m); }else{ d++; sy.deleteByData(m); sy.addFirstNode(m); } } if(sy.getLength()==6){ sy.deleteByPos(sy.getLength()-1); } sy.displayAllNodes(); System.out.println("长度"+sy.getLength()); } System.out.println("置换了"+d+"次"); } }
相关文章推荐
- spring context 初始化两次导致dubbo端口被占用
- java版本银行家算法
- 把myeclipse生成的javadoc
- java comet 长轮询的案例
- 什么是Java实例初始化块
- 实例解析观察者模式及其在Java设计模式开发中的运用
- java Pattern和Matcher详解(正则表达式)
- java执行cmd命令堵塞的另外一种处理方式
- Struts2中使用通配符
- Java的接口和抽象类详解
- java 并发多线程的声明
- java equals 使用
- java执行cmd命令出现堵塞现象的解决方法
- Json串与实体的相互转换 (不依赖于jar包 只需Eclipse环境即可)
- 深入理解Java类加载器(2):线程上下文类加载器
- 深入理解Java类加载器(1):Java类加载原理解析
- java类加载的过程
- Java学习之——线程非安全单利模式到线程安全单利模式
- JavaMail发送邮件
- JDK 卸载