算法思想:
最佳置换算法是一种理想化算法,淘汰未来最长时间内不再被访问的页面,因为未来是无法预测的,所以说是理想化的。
代码如下:
总体来说实现难度不大。
#include<iostream>
#include<vector>
#include<algorithm>
#include<map>
using namespace std;
vector<int> jincheng;
vector<int> kuai;
map<int, int> m;
int n; // 页面数
int t; // 物理块数
int cnt; // 记录缺页次数
int maxn = -1;
int main() {
jincheng.clear();
kuai.clear();
cout << "请输入页面数量:" << "\n";
cin >> n;
cout << "请输入物理块数:" << "\n";
cin >> t;
cout << "请输入页面序列:" << "\n";
int x;
for(int i = 0; i < n; i ++) {
cin >> x;
jincheng.push_back(x);
}
for(int i = 0; i < t; i ++) {
kuai.push_back(jincheng[i]);
cout << "这是访问第" << i + 1 << "个页面时的情况:\n";
for(int i = 0; i < kuai.size(); i ++) {
cout << kuai[i] << " ";
}
cout << "\n";
}
for(int i = t; i < n; i ++) {
bool flag = false;
for(int j = 0; j < t; j ++) {
if(kuai[j] == jincheng[i]) {
kuai[j] = jincheng[i];
flag = true;
}
}
if(flag == false) {
cnt ++;
m.clear();
maxn = -1;
for(int k = 0; k < t; k ++) {
bool flagg = false;
for(int r = i + 1; r < n; r ++) {
if(kuai[k] == jincheng[r]) {
maxn = max(maxn, r);
m[r] = k; // 把物理块里页面的位置在页面序列中的位置存下来
flagg = true;
break;
}
}
if(flagg == false) {
m[maxn] = k;
break;
}
}
kuai[m[maxn]] = jincheng[i];
}
cout << "这是访问第" << i + 1 << "个页面时的情况:\n";
for(int i = 0; i < t; i ++) {
cout << kuai[i] << " ";
}
cout << "\n";
}
cout << "页面置换次数为:" << "\n";
cout << cnt << "\n";
cout << "缺页率为:" << "\n";
printf("%.2lf\n", 1.0 * cnt / n);
return 0;
}