当前位置: 首页 > news >正文

【OD】【E卷】【真题】【100分】内存资源分配(PythonJavaJavaScriptC++C)

题目描述

有一个简易内存池,内存按照大小粒度分类,每个粒度有若干个可用内存资源,用户会进行一系列内存申请,需要按需分配内存池中的资源返回申请结果成功失败列表。

分配规则如下:

  • 分配的内存要大于等于内存的申请量,存在满足需求的内存就必须分配,优先分配粒度小的,但内存不能拆分使用;
  • 需要按申请顺序分配,先申请的先分配,有可用内存分配则申请结果为true;
  • 没有可用则返回false。

注意:不考虑内存释放

输入描述

输入为两行字符串

第一行为内存池资源列表,包含内存粒度数据信息,粒度数据间用逗号分割

  • 一个粒度信息内用冒号分割,冒号前为内存粒度大小,冒号后为数量
  • 资源列表不大于1024
  • 每个粒度的数量不大于4096

第二行为申请列表,申请的内存大小间用逗号分割

  • 申请列表不大于100000

如:
64:2,128:1,32:4,1:128
50,36,64,128,127

输出描述

输出为内存池分配结果

如true,true,true,false,false

示例1

输入

64:2,128:1,32:4,1:128
50,36,64,128,127

输出

true,true,true,false,false

说明

内存池资源包含:64K共2个、128K共1个、32K共4个、1K共128个的内存资源;
针对50,36,64,128,127的内存申请序列,分配的内存依次是:64,64,128,NULL,NULL,
第三次申请内存时已经将128分配出去,因此输出结果是:
true,true,true,false,false

解题思路

规则总结:

  • 按需分配内存,不能拆分。
  • 优先分配最小的满足条件的内存块。
  • 内存池中的资源一旦分配出去,就无法再次使用。
  • 若没有可用内存块满足需求,返回 false

示例解释:

输入:

64:2,128:1,32:4,1:128
50,36,64,128,127

输出:

true,true,true,false,false
解释过程:
  1. 内存池初始化

    • 内存池资源为:

      • 64K 的内存块有 2 个。
      • 128K 的内存块有 1 个。
      • 32K 的内存块有 4 个。
      • 1K 的内存块有 128 个。
  2. 申请 50K 内存

    • 50K 需要一个大于等于 50K 的内存块。
    • 从内存池中寻找,最小满足要求的内存块是 64K,因此分配一个 64K 的内存块,成功,返回 true
    • 剩余内存池:64:1, 128:1, 32:4, 1:128。
  3. 申请 36K 内存

    • 36K 需要一个大于等于 36K 的内存块。
    • 最小满足要求的内存块是 64K,因此分配一个 64K 的内存块,成功,返回 true
    • 剩余内存池:64:0, 128:1, 32:4, 1:128。
  4. 申请 64K 内存

    • 64K 需要一个大于等于 64K 的内存块。
    • 内存池中没有剩余的 64K 内存块,唯一满足条件的内存块是 128K,因此分配一个 128K 的内存块,成功,返回 true
    • 剩余内存池:64:0, 128:0, 32:4, 1:128。
  5. 申请 128K 内存

    • 128K 需要一个大于等于 128K 的内存块。
    • 但是内存池中已经没有 128K 或更大的内存块了,分配失败,返回 false
  6. 申请 127K 内存

    • 127K 需要一个大于等于 127K 的内存块。
    • 同样,内存池中没有 128K 或更大的内存块,分配失败,返回 false

最终,输出为 true,true,true,false,false

Java

import java.util.*;public class Main {public static void main(String[] args) {// 处理输入Scanner scanner = new Scanner(System.in); // 创建一个Scanner对象,用于读取控制台的输入String memoryInfo = scanner.next(); // 读取内存池资源列表String applyList = scanner.next(); // 读取申请列表// 内存信息List<Integer> memoryList = new ArrayList<>(); // 创建一个ArrayList对象,用于存储内存池中可用的内存大小List<String> memoryInfoList = new ArrayList<>(Arrays.asList(memoryInfo.split(","))); // 将内存池资源列表按逗号分隔,转换为ArrayList对象for (String info : memoryInfoList) { // 遍历内存池资源列表int colonIndex = info.indexOf(":"); // 找到冒号的位置int size = Integer.parseInt(info.substring(0, colonIndex)); // 截取内存大小int count = Integer.parseInt(info.substring(colonIndex + 1)); // 截取内存块数量for (int i = 0; i < count; i++) { // 将内存块数量的内存大小添加到内存列表中memoryList.add(size);}}// 申请信息List<Integer> applyMemoryList = new ArrayList<>(); // 创建一个ArrayList对象,用于存储申请的内存大小List<String> applyListList = new ArrayList<>(Arrays.asList(applyList.split(","))); // 将申请列表按逗号分隔,转换为ArrayList对象for (String apply : applyListList) { // 遍历申请列表applyMemoryList.add(Integer.parseInt(apply)); // 将申请的内存大小添加到申请内存列表中}// 分配内存List<Boolean> resultList = new ArrayList<>(); // 创建一个ArrayList对象,用于存储每个申请是否成功for (int applyMemory : applyMemoryList) { // 遍历申请内存列表boolean flag = false; // 定义一个标志位,用于标记是否成功分配内存for (int i = 0; i < memoryList.size(); i++) { // 遍历内存列表if (memoryList.get(i) >= applyMemory) { // 如果当前内存块的大小大于等于申请的内存大小flag = true; // 标记成功分配内存memoryList.remove(i); // 将当前内存块从内存列表中移除break; // 跳出循环}}resultList.add(flag); // 将是否成功分配内存的结果添加到结果列表中}// 输出结果for (int i = 0; i < resultList.size(); i++) { // 遍历结果列表System.out.print(resultList.get(i)); // 输出当前申请是否成功分配内存if (i != resultList.size() - 1) { // 如果不是最后一个结果System.out.print(","); // 输出逗号分隔符}}}
}

Python

memoryInfo = input() # 读取内存池资源列表
applyList = input() # 读取申请列表# 内存信息
memoryList = [] # 创建一个列表,用于存储内存池中可用的内存大小
memoryInfoList = memoryInfo.split(",") # 将内存池资源列表按逗号分隔,转换为列表
for info in memoryInfoList: # 遍历内存池资源列表colonIndex = info.index(":") # 找到冒号的位置size = int(info[:colonIndex]) # 截取内存大小count = int(info[colonIndex + 1:]) # 截取内存块数量for i in range(count): # 将内存块数量的内存大小添加到内存列表中memoryList.append(size)# 申请信息
applyMemoryList = [] # 创建一个列表,用于存储申请的内存大小
applyListList = applyList.split(",") # 将申请列表按逗号分隔,转换为列表
for apply in applyListList: # 遍历申请列表applyMemoryList.append(int(apply)) # 将申请的内存大小添加到申请内存列表中# 分配内存
resultList = [] # 创建一个列表,用于存储每个申请是否成功
for applyMemory in applyMemoryList: # 遍历申请内存列表flag = False # 定义一个标志位,用于标记是否成功分配内存for i in range(len(memoryList)): # 遍历内存列表if memoryList[i] >= applyMemory: # 如果当前内存块的大小大于等于申请的内存大小flag = True # 标记成功分配内存memoryList.pop(i) # 将当前内存块从内存列表中移除break # 跳出循环resultList.append(flag) # 将是否成功分配内存的结果添加到结果列表中# 输出结果
for i in range(len(resultList)): # 遍历结果列表print(resultList[i], end='') # 输出当前申请是否成功分配内存if i != len(resultList) - 1: # 如果不是最后一个结果print(',', end='') # 输出逗号分隔符

JavaScript

const readline = require('readline');const rl = readline.createInterface({input: process.stdin,output: process.stdout
});let memoryInfo, applyList;rl.on('line', (input) => {if (!memoryInfo) {memoryInfo = input;} else if (!applyList) {applyList = input;rl.close();}
});rl.on('close', () => {// 处理输入const memoryList = [];const memoryInfoArr = memoryInfo.split(',');for (let i = 0; i < memoryInfoArr.length; i++) {const [sizeStr, countStr] = memoryInfoArr[i].split(':');const size = parseInt(sizeStr);const count = parseInt(countStr);for (let j = 0; j < count; j++) {memoryList.push(size);}}// 申请信息const applyMemoryList = applyList.split(',').map(Number);// 分配内存const resultList = [];for (let i = 0; i < applyMemoryList.length; i++) {let flag = false;for (let j = 0; j < memoryList.length; j++) {if (memoryList[j] >= applyMemoryList[i]) {flag = true;memoryList.splice(j, 1);break;}}resultList.push(flag);}// 输出结果console.log(resultList.map((res) => res ? 'true' : 'false').join(','));
});

C++

#include <iostream>
#include <vector>
#include <sstream>using namespace std;int main() {// 处理输入string memoryInfo, applyList;cin >> memoryInfo >> applyList;// 内存信息vector<int> memoryList;stringstream ss(memoryInfo);string info;while (getline(ss, info, ',')) {int colonIndex = info.find(":");int size = stoi(info.substr(0, colonIndex));int count = stoi(info.substr(colonIndex + 1));for (int i = 0; i < count; i++) {memoryList.push_back(size);}}// 申请信息vector<int> applyMemoryList;stringstream ss2(applyList);string apply;while (getline(ss2, apply, ',')) {applyMemoryList.push_back(stoi(apply));}// 分配内存vector<bool> resultList;for (int applyMemory : applyMemoryList) {bool flag = false;for (int i = 0; i < memoryList.size(); i++) {if (memoryList[i] >= applyMemory) {flag = true;memoryList.erase(memoryList.begin() + i);break;}}resultList.push_back(flag);}// 输出结果for (int i = 0; i < resultList.size(); i++) {cout << (resultList[i] ? "true" : "false");if (i != resultList.size() - 1) {cout << ",";}}return 0;
}

C语言

#include <stdio.h>
#include <string.h>
#include <stdlib.h>#define MAX_MEMORY_BLOCKS 1000  // 最大内存块数量
#define MAX_APPLY_REQUESTS 1000 // 最大申请请求数量
#define MAX_INPUT_LENGTH 1024   // 最大输入字符串长度int main() {char memoryInfo[MAX_INPUT_LENGTH], applyList[MAX_INPUT_LENGTH];int memoryList[MAX_MEMORY_BLOCKS];   // 用于存储内存块大小的数组int memoryCount = 0;                 // 内存块总数int applyMemoryList[MAX_APPLY_REQUESTS]; // 用于存储内存申请大小的数组int applyCount = 0;                  // 申请总数int resultList[MAX_APPLY_REQUESTS];  // 用于存储每次申请结果的数组// 输入内存池信息和申请列表scanf("%s", memoryInfo);scanf("%s", applyList);// 处理内存池信息char *token = strtok(memoryInfo, ",");  // 使用strtok按逗号分割字符串while (token != NULL) {char *colon = strchr(token, ':');   // 找到冒号位置int size = atoi(token);             // 内存块大小int count = atoi(colon + 1);        // 内存块数量// 将每个内存块大小添加到内存列表中for (int i = 0; i < count; i++) {if (memoryCount < MAX_MEMORY_BLOCKS) {memoryList[memoryCount++] = size;}}token = strtok(NULL, ",");  // 获取下一个逗号分割的部分}// 处理申请列表token = strtok(applyList, ",");  // 使用strtok按逗号分割字符串while (token != NULL) {if (applyCount < MAX_APPLY_REQUESTS) {applyMemoryList[applyCount++] = atoi(token);  // 将申请大小存入数组}token = strtok(NULL, ",");  // 获取下一个逗号分割的部分}// 处理每次申请for (int i = 0; i < applyCount; i++) {int applyMemory = applyMemoryList[i];int success = 0;  // 标记是否成功分配内存// 遍历内存池,找到第一个大于等于申请大小的内存块for (int j = 0; j < memoryCount; j++) {if (memoryList[j] >= applyMemory) {success = 1;  // 找到合适的内存块// 将该内存块从数组中移除,通过覆盖方式for (int k = j; k < memoryCount - 1; k++) {memoryList[k] = memoryList[k + 1];}memoryCount--;  // 更新内存块数量break;}}resultList[i] = success;  // 记录申请结果}// 输出分配结果for (int i = 0; i < applyCount; i++) {if (resultList[i]) {printf("true");} else {printf("false");}if (i != applyCount - 1) {printf(",");}}printf("\n");return 0;
}

相关文章:

【OD】【E卷】【真题】【100分】内存资源分配(PythonJavaJavaScriptC++C)

题目描述 有一个简易内存池&#xff0c;内存按照大小粒度分类&#xff0c;每个粒度有若干个可用内存资源&#xff0c;用户会进行一系列内存申请&#xff0c;需要按需分配内存池中的资源返回申请结果成功失败列表。 分配规则如下&#xff1a; 分配的内存要大于等于内存的申请…...

Linux基础项目开发day05:量产工具——页面系统

文章目录 一、数据结构抽象page_manager.h 二、页面管理器page_manager.c 三、单元测试1、main.page.c2、page_test.c3、Makefile修改3.1、unittest中的Makefile3.2、page中的Makefile 四、上机实验 前言 前面实现了显示、输入、文字、UI系统&#xff0c;现在我们就来实现页面的…...

保护企业终端安全,天锐DLP帮助企业智能管控终端资产

为有效预防员工非法调包公司的软硬件终端资产&#xff0c;企业管理员必须建立高效的企业终端安全管控机制&#xff0c;确保能够即时洞察并确认公司所有软硬件资产的状态变化。这要求企业要有一套能够全面管理终端资产的管理系统&#xff0c;确保任何未经授权的资产变动都能被迅…...

2024市场营销第3次课

品牌管理 1.认识品牌 品牌定义&#xff1a;一个名称、术语、标志、符号或设计&#xff0c;或者是它们的组合&#xff0c;用来识别某个销售商或某一群销售商的产品或服务&#xff0c;并使其与竞争者的产品或服务区分开来。 品牌构成&#xff1a;成功品牌的构成都是由外及内的…...

Python基础之函数的定义与调用

一、函数的定义 在Python中&#xff0c;函数是一段可重复使用的代码块&#xff0c;用于完成特定的任务。可以使用def关键字来定义函数。 语法如下&#xff1a; def function_name(parameters): """docstring""" # function body return expres…...

GPU在AI绘画中的作用以及GPU的选择

大家好&#xff0c;我是Shelly&#xff0c;一个专注于输出AI工具和科技前沿内容的AI应用教练&#xff0c;体验过300款以上的AI应用工具。关注科技及大模型领域对社会的影响10年。关注我一起驾驭AI工具&#xff0c;拥抱AI时代的到来。 GPU在AI绘画中的作用&#xff1a; GPU在A…...

【火山引擎】 Chat实践 | 大模型调用实践 | python

目录 一 前期工作 二 Doubao-pro-4k_test实践 一 前期工作 1 已在火山方舟控制台在线推理页面创建了推理接入点 ,接入大语言模型并获取接入点 ID。 2 已参考安装与初始化中的步骤完成 SDK 安装和访问凭证配置...

mysql学习教程,从入门到精通,SQL 注入(42)

1、 SQL 注入 SQL 注入是一种严重的安全漏洞&#xff0c;它允许攻击者通过操纵 SQL 查询来访问、修改或删除数据库中的数据。由于 SQL 注入的潜在危害&#xff0c;我不能提供具体的恶意代码示例。然而&#xff0c;我可以向你展示如何防御 SQL 注入&#xff0c;并解释其工作原理…...

图论day60|108.冗余连接(卡码网) 、109.冗余连接II(卡码网)【并查集 摧毁信心的一题,胆小的走开!】

图论day60|108.冗余连接&#xff08;卡码网&#xff09;、109.冗余连接II&#xff08;卡码网&#xff09;【并查集 摧毁信心的一题&#xff0c;胆小的走开&#xff01;】 108.冗余连接&#xff08;卡码网&#xff09;109.冗余连接II&#xff08;卡码网&#xff09;【并查集 摧毁…...

即使是编程新手,也能利用ChatGPT编写高质量的EA

在外汇交易领域&#xff0c;MetaTrader是一款备受欢迎的交易软件&#xff0c;包括MT5和MT4&#xff0c;提供了众多强大的分析工具和自动化交易功能。对于没有编程经验的新手而言&#xff0c;编写专家顾问&#xff08;EA&#xff09;可能显得既复杂又令人望而却步。幸运的是&…...

StarRocks大批量数据导入方案-使用 Routine Load 导入数据

本文详细介绍如何使用Routine Load 导入数据 一、准备工作 1.1 安装基础环境 主要是安装StarRocks和Kafka&#xff0c;本文直接跳过不做详细介绍~ 二、概念及原理 2.1 概念 导入作业&#xff08;Load job&#xff09; 导入作业会常驻运行&#xff0c;当导入作业的状态为 R…...

从零开始学PHP之输出语句变量常量

一、 输出方式 在 PHP 中输出方式&#xff1a; echo&#xff0c;print&#xff0c;print_r&#xff0c;var_dump 1、echo和print为php的输出语句 2、var_dump&#xff0c;print_r为php的输出函数 &#xff08;这里不做介绍&#xff09;echo 和 print 区别 1、echo - 可以输出…...

二叉树算法之字典树(Trie)详细解读

字典树&#xff08;Trie&#xff0c;也称前缀树或单词查找树&#xff09;是一种用于快速查找字符串的数据结构&#xff0c;主要应用于字符串集合的高效存储和查找。字典树特别适合处理具有相同前缀的大量字符串集合&#xff0c;比如单词自动补全、拼写检查等场景。 1. 字典树的…...

butterfly侧边栏音乐模块

方法1.美观但换页后没法播放 1.blog根目录/source文件夹下新建_data文件夹&#xff08;如果没有_data文件夹&#xff09; 2.在刚刚的_data文件夹里创建widget.yml文件 bottom:- class_name: user-musicid_name: user-musicname: 音乐icon: fas fa-heartbeatorder:html: <…...

【论文阅读】Detach and unite: A simple meta-transfer for few-shot learning

分离与联合&#xff1a;一种用于小样本学习的简单元迁移方法 引用&#xff1a;Zheng Y, Zhang X, Tian Z, et al. Detach and unite: A simple meta-transfer for few-shot learning[J]. Knowledge-Based Systems, 2023, 277: 110798. 论文地址&#xff1a;下载地址 论文代码&a…...

Java中的动态代理——介绍与使用示例

Java中的动态代理其实就是一种“代理”模式&#xff0c;在运行时帮我们创建一个“代理对象”&#xff0c;通过这个代理对象可以在不改变原本方法的情况下&#xff0c;做一些额外的事情&#xff0c;比如记录日志、检查权限等。这种代理机制非常灵活和实用&#xff0c;特别是在像…...

微信开发者工具:音乐小程序报错

报错信息 GET http://localhost:3000/1.mp3 net::ERR CONNECTION REFUSED (env: Windows,mp,1.06.2303220;lib:3.6.0) 原因&#xff1a;小程序没有直接获取本地文件&#xff0c;为了提高访问速度&#xff0c;而采用放到网络服务器中网络访问的方式获取文件内容 解决办法&#…...

P2-3与P2-4.【C语言基本数据类型、运算符和表达式】第三节与第四节

讲解视频&#xff1a; P2-3.【基本数据类型、运算符和表达式】第三节 P2-4.【基本数据类型、运算符和表达式】第四节 目录 必备知识与理论 任务实施 必备知识与理论 C语言中把除了控制语句和输入输出以外的几乎所有的基本操作都作为运算符处理。 其运算符和表达式数量之多&a…...

Python | Leetcode Python题解之第492题构造矩形

题目&#xff1a; 题解&#xff1a; class Solution:def constructRectangle(self, area: int) -> List[int]:w int(sqrt(area))while area % w:w - 1return [area // w, w]...

新版vs code + Vue高亮、语法自动补全插件

vs code 版本或及以上 安装以下三个插件插件 Vetur Vue语法支持。包括语法高亮、语法代码提示、语法lint检测 ESLint语法纠错 Prettier 2.左下角设置 3.进行配置 配置内容&#xff1a; {"editor.fontSize": 20,"window.zoomLevel": 1,"workben…...

OpenLayers 可视化之热力图

注&#xff1a;当前使用的是 ol 5.3.0 版本&#xff0c;天地图使用的key请到天地图官网申请&#xff0c;并替换为自己的key 热力图&#xff08;Heatmap&#xff09;又叫热点图&#xff0c;是一种通过特殊高亮显示事物密度分布、变化趋势的数据可视化技术。采用颜色的深浅来显示…...

C++初阶-list的底层

目录 1.std::list实现的所有代码 2.list的简单介绍 2.1实现list的类 2.2_list_iterator的实现 2.2.1_list_iterator实现的原因和好处 2.2.2_list_iterator实现 2.3_list_node的实现 2.3.1. 避免递归的模板依赖 2.3.2. 内存布局一致性 2.3.3. 类型安全的替代方案 2.3.…...

树莓派超全系列教程文档--(62)使用rpicam-app通过网络流式传输视频

使用rpicam-app通过网络流式传输视频 使用 rpicam-app 通过网络流式传输视频UDPTCPRTSPlibavGStreamerRTPlibcamerasrc GStreamer 元素 文章来源&#xff1a; http://raspberry.dns8844.cn/documentation 原文网址 使用 rpicam-app 通过网络流式传输视频 本节介绍来自 rpica…...

Golang 面试经典题:map 的 key 可以是什么类型?哪些不可以?

Golang 面试经典题&#xff1a;map 的 key 可以是什么类型&#xff1f;哪些不可以&#xff1f; 在 Golang 的面试中&#xff0c;map 类型的使用是一个常见的考点&#xff0c;其中对 key 类型的合法性 是一道常被提及的基础却很容易被忽视的问题。本文将带你深入理解 Golang 中…...

SCAU期末笔记 - 数据分析与数据挖掘题库解析

这门怎么题库答案不全啊日 来简单学一下子来 一、选择题&#xff08;可多选&#xff09; 将原始数据进行集成、变换、维度规约、数值规约是在以下哪个步骤的任务?(C) A. 频繁模式挖掘 B.分类和预测 C.数据预处理 D.数据流挖掘 A. 频繁模式挖掘&#xff1a;专注于发现数据中…...

AtCoder 第409​场初级竞赛 A~E题解

A Conflict 【题目链接】 原题链接&#xff1a;A - Conflict 【考点】 枚举 【题目大意】 找到是否有两人都想要的物品。 【解析】 遍历两端字符串&#xff0c;只有在同时为 o 时输出 Yes 并结束程序&#xff0c;否则输出 No。 【难度】 GESP三级 【代码参考】 #i…...

CentOS下的分布式内存计算Spark环境部署

一、Spark 核心架构与应用场景 1.1 分布式计算引擎的核心优势 Spark 是基于内存的分布式计算框架&#xff0c;相比 MapReduce 具有以下核心优势&#xff1a; 内存计算&#xff1a;数据可常驻内存&#xff0c;迭代计算性能提升 10-100 倍&#xff08;文档段落&#xff1a;3-79…...

Spring AI 入门:Java 开发者的生成式 AI 实践之路

一、Spring AI 简介 在人工智能技术快速迭代的今天&#xff0c;Spring AI 作为 Spring 生态系统的新生力量&#xff0c;正在成为 Java 开发者拥抱生成式 AI 的最佳选择。该框架通过模块化设计实现了与主流 AI 服务&#xff08;如 OpenAI、Anthropic&#xff09;的无缝对接&…...

《C++ 模板》

目录 函数模板 类模板 非类型模板参数 模板特化 函数模板特化 类模板的特化 模板&#xff0c;就像一个模具&#xff0c;里面可以将不同类型的材料做成一个形状&#xff0c;其分为函数模板和类模板。 函数模板 函数模板可以简化函数重载的代码。格式&#xff1a;templa…...

GitFlow 工作模式(详解)

今天再学项目的过程中遇到使用gitflow模式管理代码&#xff0c;因此进行学习并且发布关于gitflow的一些思考 Git与GitFlow模式 我们在写代码的时候通常会进行网上保存&#xff0c;无论是github还是gittee&#xff0c;都是一种基于git去保存代码的形式&#xff0c;这样保存代码…...