```c #include <stdio.h> // 定义位示图的大小 #define SIZE 64 // 定义全局位示图数组 int bitmap[SIZE] = {0}; // 初始化位示图,将已占用的块标记为 1 void initBitmap() { bitmap[1] = 1; bitmap[3] = 1; bitmap[5] = 1; bitmap[7] = 1; bitmap[9] = 1; bitmap[11] = 1; bitmap[13] = 1; bitmap[15] = 1; bitmap[17] = 1; bitmap[19] = 1; } // 查找空闲块 int findFreeBlock() { for (int i = 0; i < SIZE; i++) { if (bitmap[i] == 0) { bitmap[i] = 1; return i; } } return -1; } // 处理进程请求 void handleProcessRequest(int processNumber, int blockCount) { int startBlock = -1; for (int i = 0; i < blockCount; i++) { int freeBlock = findFreeBlock(); if (freeBlock == -1) { printf("wait\n"); return; } if (i == 0) { startBlock = freeBlock; } } int pageNumber; scanf("%d %d", &processNumber, &pageNumber); if (pageNumber >= 0 && pageNumber <= 53) { printf("%d\n", startBlock + pageNumber); } else { printf("error\n"); } } int main() { initBitmap(); int blockRequests[4]; printf("请输入四个进程申请的内存块数,以空格分隔:\n"); for (int i = 0; i < 4; i++) { scanf("%d", &blockRequests[i]); } for (int i = 0; i < 4; i++) { handleProcessRequest(i + 1, blockRequests[i]); } return 0; } ``` 额外需要注意的逻辑点: 1. 输入的进程申请块数和页号要进行有效范围的判断。 2. 位示图的更新操作要确保准确,避免重复标记或漏标记。 3. 处理多个进程请求时,要注意顺序和资源分配的合理性。 [2024-12-12 16:33:18 | AI写代码神器 | 602点数解答]