C++实现分页式存储系统位示图内存分配与进程页面查询
#include <iostream> #include <vector> #include <string> using namespace std; // 初始化位示图 vector<int> bitMap(64, 0); // 进程结构体 struct Process { int processNum; int pageRequested; }; // 判断是否有足够的内存空间 bool checkSpace(int numPages) { int count = 0; for (int i = 0; i < 64; i++) { if (bitMap[i] == 0) { count++; } if (count == numPages) { return true; } } return false; } // 分配内存空间给进程 int allocateMemory(Process process) { int numPages = process.pageRequested; if (checkSpace(numPages)) { int startIndex = 0; for (int i = 0; i < numPages; i++) { while (bitMap[startIndex] != 0) { startIndex++; } bitMap[startIndex] = process.processNum; } return startIndex; } else { return -1; } } int main() { vector<Process> processes; for (int i = 0; i < 4; i++) { int pageRequested; cin >> pageRequested; Process newProcess = {i+1, pageRequested}; processes.push_back(newProcess); } int processNum, pageNum; cin >> processNum >> pageNum; for (Process process : processes) { if (process.processNum == processNum) { int result = allocateMemory(process); if (result != -1) { if (pageNum >= 0 && pageNum < process.pageRequested) { cout << result << endl; } else { cout << "error" << endl; } } else { cout << "wait" << endl; } break; } } return 0; } ######[AI写代码神器 | 1154点数解答 | 2024-11-21 15:45:29]
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)384
- 补全含错误代码:Vue结合Element UI组件实现查询、新增及表格展示功能 ( | 400点数解答 | 2023-12-19 15:20:50)454
- 单线程频繁查ClickHouse致CPU飙升?这些优化方案速看!(DeepSeek | 491点数解答 | 2025-02-13 17:49:54)251
- MySQL:巧用 NOT LIKE 查询字段不包含特定字符串及注意要点 (DeepSeek | 264点数解答 | 2025-02-13 18:25:01)196
- 51 单片机:定时器 0 实现 8 个 LED 循环点亮,附代码及优化建议(字节豆包 | 1193点数解答 | 2024-12-27 15:10:29)352
- iOS开发:手把手教你完整实现代理模式,含声明与实现步骤!(阿里通义 | 268点数解答 | 2023-11-08 00:39:55)278
- JavaScript 开发:用 Animation 实现自定义动画的简易教程 (阿里通义 | 333点数解答 | 2023-11-09 01:50:07)271
- 用 JS 中 for 循环实现 1 到 100 相加并输出结果到页面的完整代码 ( | 240点数解答 | 2024-05-20 22:11:29)500
- 用 JS 的 while 循环实现 1 到 100 相加并输出到页面的代码揭秘( | 47点数解答 | 2024-05-20 22:16:48)389
- Vue.js 与 Matter.js 碰撞:轻松实现物理模拟全攻略 (讯飞星火 | 522点数解答 | 2024-05-29 22:26:06)455
- JS实现移动端网页快捷键创建方式及注意事项(阿里通义 | 284点数解答 | 2024-06-05 19:02:59)285
- 车载系统 UML 类图设计:涵盖 Car、Engine、娱乐系统等的完整类定义与关系解析 (字节豆包 | 760点数解答 | 2024-08-15 22:51:04)332