1. 算法介绍
      1. FIFO:该算法总是淘汰最先进入内存的页面,即选择在内存中驻留时间最久的页面予以淘汰。该算法实现简单,只需把一个进程已调入内存的页面,按先后次序链接成一个队列,并设置一个指针,称为替换指针,使它总是指向最老的页面。但该算法与进程实际运行的规律不相适应,因为在进程中,有些页面经常被访问,比如,含有全局变量、常用函数、例程等的页面,FIFO 算法并不能保证这些页面不被淘汰。
      2. LRU(least recently used)是将近期最不会访问的数据给淘汰掉,LRU是认为最近被使用过的数据,那么将来被访问的概率也多,最近没有被访问,那么将来被访问的概率也比较低。LRU算法简单,存储空间没有被浪费,所以还是用的比较广泛的。
  2. 实现思路
    1. 数组作为内存块,另一个数组存储页号
    2. FIFS:

      读入的页号首先在内存块中查找,没有查找到,当前物理块若为空,则调入页号,若非空,则按照先到先出的顺序,调入调出,若查找到页号,则继续查找下一个。

    3. LUR:

      内存块为空时,先读入的页号进入内存块直到内存块满,将其等待时间都置为0,接下来的页号,如果在内存块中找到,则将该页号的等待时间置为0,若找不到,则查找内存块中等待时间最长的页号置换出去,新进来的页号等待时间置为0。然后将内存块中其余页号的等待时间都加1。

    4. 流程图:

    5. lur:

      FIFS:

  3. 代码
  4.  #include<iostream>
    using namespace std;
    //伪代码: 内存大小,作业号,
    //物理块,
    int a[],len,b[],i,j,n;
    int c[][]; void readn(int n){ cout<<"请输入页面号(-1结束)";
    len=;
    int m=;
    while(m!=-){
    cin>>a[len];
    m=a[len];
    len++;
    }
    len=len-;
    cout<<"输入完毕"<<endl;
    // for( j=0;j<len;j++){
    // cout<<a[j];
    // }
    } void FIFO(int n,int a[]){
    int cnum=;
    for( j=;j<n;j++){
    b[j]=a[j]; }
    //输出第一个b[n],
    cout<<"当前物理块存放的页号:";
    for( j=;j<n;j++){
    cout<<b[j]<<" ";
    }
    cout<<endl;
    int x=,flag=,sum=;
    for( i=n-;i<len;i++){ for( j=;j<n;j++){
    if(a[i]==b[j])
    break;
    }
    int q=x;
    if(j>=n){
    b[x]=a[i];
    x=(x+)%n; flag=;
    sum++;
    }
    if(flag==){
    cout<<"置换了b["<<q<<"]"<<endl;
    }
    cout<<"当前物理块存放的页号:";
    for( j=;j<n;j++){
    cout<<b[j]<<" ";
    }
    cout<<endl;
    flag=;
    }
    //计算缺页率
    cout<<"FIFO缺页次数:"<<sum+n<<endl;
    cout<<"FIFO置换次数:"<<sum <<endl;
    cout<<"FIFO缺页率:"<<(double)(sum+n)/len<<endl; } void LRU(int n,int a[]){ int cnum=;
    for( j=;j<n;j++){
    c[j][]=a[j];
    c[j][]=;
    }
    //输出第一个b[n],
    cout<<"当前物理块存放的页号:";
    for( j=;j<n;j++){
    cout<<c[j][]<<" ";
    }
    cout<<endl;
    int x=,flag=,sum=;
    for( i=n-;i<len;i++){
    //查找在不在内存里面
    for( j=;j<n;j++){
    if(a[i]==c[j][]){
    c[j][]=;//将时间恢复为0 //等待的时间加1
    for(int k=;k<n;k++){
    if(c[k][]!=a[i]){
    c[k][]++;
    }
    }
    break;
    } }
    int q;
    if(j>=n){//不在内存里面,找最久没用的
    int tmp=c[x][],zhen=x;
    for(int l=;l<n;l++){
    if(c[l][]>tmp){
    tmp=c[l][];
    zhen=l;
    }
    }
    x=zhen;
    q=x;
    c[x][]=a[i];
    c[x][]=;
    for(int k=;k<n;k++){
    if(c[k][]!=a[i]){
    c[k][]++;
    }
    }
    x=(x+)%n;
    flag=;
    sum++;
    }
    if(flag==){
    cout<<"置换了c["<<q<<"]"<<endl;
    }
    cout<<"当前物理块存放的页号:";
    for( j=;j<n;j++){
    cout<<c[j][]<<" ";
    }
    cout<<endl;
    flag=;
    }
    //计算缺页率
    cout<<"LUR缺页次数:"<<sum+n<<endl;
    cout<<"LUR置换次数:"<<sum <<endl;
    cout<<"LUR缺页率:"<<(double)(sum+n)/len<<endl; } int main(){
    //物理块
    cout<<"请输入物理块大小";
    cin>>n;
    readn(n);
    cout<<"FIFO算法:";
    FIFO(n,a);
    cout<<endl;
    cout<<"LRU算法:";
    LRU(n,a); return ;
    }
  5. 运行结果

【页面置换算法】LRC算法和FIFS算法的更多相关文章

  1. 网络流之最大流算法(EK算法和Dinc算法)

    最大流 网络流的定义: 在一个网络(有流量)中有两个特殊的点,一个是网络的源点(s),流量只出不进,一个是网络的汇点(t),流量只进不出. 最大流:就是求s-->t的最大流量 假设 u,v 两个 ...

  2. 单源最短路径算法——Bellman-ford算法和Dijkstra算法

     BellMan-ford算法描述 1.初始化:将除源点外的所有顶点的最短距离估计值 dist[v] ← +∞, dist[s] ←0; 2.迭代求解:反复对边集E中的每条边进行松弛操作,使得顶点集V ...

  3. TCP_NODELAY和TCP_CORK nagle算法和cork算法

    TCP_NODELAY 默认情况下,发送数据採用Nagle 算法.这样尽管提高了网络吞吐量,可是实时性却减少了,在一些交互性非常强的应用程序来说是不同意的.使用TCP_NODELAY选项能够禁止Nag ...

  4. FIFO调度算法和LRU算法

    一.理论 FIFO:先进先出调度算法 LRU:最近最久未使用调度算法 两者都是缓存调度算法,经常用作内存的页面置换算法. 打一个比方,帮助你理解.你有很多的书,比如说10000本.由于你的书实在太多了 ...

  5. 使用Apriori算法和FP-growth算法进行关联分析

    系列文章:<机器学习实战>学习笔记 最近看了<机器学习实战>中的第11章(使用Apriori算法进行关联分析)和第12章(使用FP-growth算法来高效发现频繁项集).正如章 ...

  6. 最小生成树---Prim算法和Kruskal算法

    Prim算法 1.概览 普里姆算法(Prim算法),图论中的一种算法,可在加权连通图里搜索最小生成树.意即由此算法搜索到的边子集所构成的树中,不但包括了连通图里的所有顶点(英语:Vertex (gra ...

  7. mahout中kmeans算法和Canopy算法实现原理

    本文讲一下mahout中kmeans算法和Canopy算法实现原理. 一. Kmeans是一个很经典的聚类算法,我想大家都非常熟悉.虽然算法较为简单,在实际应用中却可以有不错的效果:其算法原理也决定了 ...

  8. 转载:最小生成树-Prim算法和Kruskal算法

    本文摘自:http://www.cnblogs.com/biyeymyhjob/archive/2012/07/30/2615542.html 最小生成树-Prim算法和Kruskal算法 Prim算 ...

  9. 0-1背包的动态规划算法,部分背包的贪心算法和DP算法------算法导论

    一.问题描述 0-1背包问题,部分背包问题.分别实现0-1背包的DP算法,部分背包的贪心算法和DP算法. 二.算法原理 (1)0-1背包的DP算法 0-1背包问题:有n件物品和一个容量为W的背包.第i ...

随机推荐

  1. codeforces 1153 D

    cf-551-div2-D C. Serval and Parenthesis Sequence 题意:给定由'(',')','?'组成的字符串,问是否能将其中的?全部换成'(‘,’)'使得字符串的任 ...

  2. Beta 冲刺(7/7)

    目录 摘要 团队部分 个人部分 摘要 队名:小白吃 组长博客:hjj 作业博客:beta冲刺(7/7) 后敬甲(组长) 过去两天完成了哪些任务 ppt制作 视频拍摄 接下来的计划 准备答辩 还剩下哪些 ...

  3. python学习第37天

    MySQL数据库 数据库的优势 什么是数据(Data) 什么是数据库(DataBase,简称DB) 什么是数据库管理系统(DataBase Managerment System 简称DBMS) 数据库 ...

  4. nvm的使用

    nvm能下载并按照指定 的版本,还能切换已安装好的版本,相当的好用

  5. 定时-thinkphp

    链接:https://pan.baidu.com/s/1wHayb9fYOiiMB3Scms0iRQ 提取码:51ex 复制这段内容后打开百度网盘手机App,操作更方便哦

  6. Java序列化随记

    序列化简介: 程序中的对象并不只是存在内存中,还需要传输网络,或者保存起来下次再加载出来用,因此需要Java序列化技术. Java序列化技术正是将对象转变成一串由二进制字节组成的数组,可以通过将二进制 ...

  7. react安装 项目构建

    1.nodejs安装 下载安装包,解压.如果是已编译文件,在/etc/profile中设置PATH(/etc/profile文件中的变量设置,所有用户可用,但需求重启服务器),并source /etc ...

  8. 方法总结:如何实现html页面自动刷新

    使用场景: 1. 页面需要定时刷新,实时加载数据,需要实时查看监控数据(H5中的WebSocket和SSE可以实现局部刷新) 2. 一定时间之后跳转到指定页面(登录注册之类) 3. 前端开发使用伪数据 ...

  9. virtualenv Mac版

    环境 MAC python 3.6.7 安装python python官网下载3.6.7版本,默认安装 安装完成后检查是否安装成功: python3.6 确认安装目录:which python3.6 ...

  10. UOJ#424. 【集训队作业2018】count 多项式,FFT,矩阵

    原文链接https://www.cnblogs.com/zhouzhendong/p/UOJ424.html 题解 主席太神仙了! 首先我们把题意转化成:对所有挺好序列建 笛卡尔树,有多少笛卡尔树互不 ...