java版本存储器管理LRU

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+"次");

     }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值