操作系统 最佳置换算法 (C++实现 操作系统实验)

算法思想:

最佳置换算法是一种理想化算法,淘汰未来最长时间内不再被访问的页面,因为未来是无法预测的,所以说是理想化的。

代码如下:

总体来说实现难度不大。

#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;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值