codeforces 7B
1 second
64 megabytes
standard input
standard output
There is little time left before the release of the first national operating system BerlOS. Some of its components are not finished yet — the memory manager is among them. According to the developers' plan, in the first release the memory manager will be very simple and rectilinear. It will support three operations:
- alloc n — to allocate n bytes of the memory and return the allocated block's identifier x;
- erase x — to erase the block with the identifier x;
- defragment — to defragment the free memory, bringing all the blocks as close to the beginning of the memory as possible and preserving their respective order;
The memory model in this case is very simple. It is a sequence of m bytes, numbered for convenience from the first to the m-th.
The first operation alloc n takes as the only parameter the size of the memory block that is to be allocated. While processing this operation, a free block of n successive bytes is being allocated in the memory. If the amount of such blocks is more than one, the block closest to the beginning of the memory (i.e. to the first byte) is prefered. All these bytes are marked as not free, and the memory manager returns a 32-bit integer numerical token that is the identifier of this block. If it is impossible to allocate a free block of this size, the function returns NULL.
The second operation erase x takes as its parameter the identifier of some block. This operation frees the system memory, marking the bytes of this block as free for further use. In the case when this identifier does not point to the previously allocated block, which has not been erased yet, the function returns ILLEGAL_ERASE_ARGUMENT.
The last operation defragment does not have any arguments and simply brings the occupied memory sections closer to the beginning of the memory without changing their respective order.
In the current implementation you are to use successive integers, starting with 1, as identifiers. Each successful alloc operation procession should return following number. Unsuccessful alloc operations do not affect numeration.
You are to write the implementation of the memory manager. You should output the returned value for each alloc command. You should also output ILLEGAL_ERASE_ARGUMENT for all the failed erase commands.
The first line of the input data contains two positive integers t and m (1 ≤ t ≤ 100;1 ≤ m ≤ 100), where t — the amount of operations given to the memory manager for processing, and m — the available memory size in bytes. Then there follow t lines where the operations themselves are given. The first operation is alloc n (1 ≤ n ≤ 100), where n is an integer. The second one is erase x, where x is an arbitrary 32-bit integer numerical token. The third operation is defragment.
Output the sequence of lines. Each line should contain either the result of alloc operation procession , or ILLEGAL_ERASE_ARGUMENT as a result of failed erase operation procession. Output lines should go in the same order in which the operations are processed. Successful procession of alloc operation should return integers, starting with 1, as the identifiers of the allocated blocks.
6 10
alloc 5
alloc 3
erase 1
alloc 6
defragment
alloc 6
1
2
NULL
3
一道纯模拟题,模拟内存分配过程。(os的首次适应算法
a:从前往后寻找一个满足大小的内存空间,放进去并给个编号(编号一直累加
e:清空给定编号的空间
d:把所有内存块移到最前面,空闲块都存在最后面了。
这题有两个大坑:1.内存块移到前面时不改变顺序,这个顺序不是编号的顺序,而是他们内存块的位置顺序。2.不合理编号的处理要细心点。
附ac代码:
1 #include <cstdio>
2 #include <cstring>
3 #include <string>
4 #include <iostream>
5 #include <algorithm>
6 using namespace std;
7 string op;
8 int mem[111];
9 int idm[111];
10 struct nod
11 {
12 int st;
13 int ed;
14 int id;
15 }nd[111];
16 bool cmp(nod a,nod b)
17 {
18 if(a.st<b.st) return 1;
19 return 0;
20 }
21 int main()
22 {
23 ios::sync_with_stdio(false);
24 cin.tie(0);
25 cout.tie(0);
26 int t,m;
27 cin>>t>>m;
28 for(int i=1;i<=111;++i)
29 nd[i].id=i;
30
31 int u,id=1;
32 for(int i=1;i<=t;++i)
33 {
34
35 cin>>op;
36 if(op[0]=='a')
37 {
38 cin>>u;
39
40
41 int j=1,sum=0;
42 // cout<<"m:"<<mem[1]<<endl;
43 for(j=1;j<=m;++j)
44 {
45 if(mem[j]==0)
46 {
47 sum++;
48 }
49 else
50 {
51 sum=0;
52 }
53 if(sum==u)
54 {
55 int k=j;
56 while(sum!=0)
57 {
58 mem[k-sum+1]=1;
59 sum--;
60 }
61 break;
62 }
63 }
64 if(j==m+1) cout<<"NULL"<<endl;
65 else
66 {
67 cout<<id<<endl;
68 idm[id]=1;
69 nd[id].st=j-u+1;
70
71 nd[id++].ed=j;
72 // cout<<nd[id-1].st<<nd[id-1].ed<<endl;
73 }
74 }
75 else if(op[0]=='e')
76 {
77 cin>>u;
78 if(u<0 || u>id || idm[u]==0)
79 {
80 cout<<"ILLEGAL_ERASE_ARGUMENT"<<endl;
81 }
82 else
83 {
84 // cout<<nd[id-1].st<<nd[id-1].ed<<endl;
85 idm[u]=0;
86 for(int k=1;k<id;++k)
87 {
88
89 if(nd[k].id==u)
90 {
91
92 for(int j=nd[k].st;j<=nd[k].ed;++j)
93 {
94
95 mem[j]=0;
96 }
97 }
98 }
99
100 }
101 }
102 else
103 {
104 int sum=0,x=1;
105 for(int k=1;k<=m;++k)
106 {
107 if(mem[k]==1)
108 sum++;
109 }
110 memset(mem,0,sizeof(mem));
111 for(int k=1;k<=sum;++k)
112 mem[k]=1;
113 sort(nd+1,nd+id,cmp);
114 for(int k=1;k<id;++k)
115 {
116
117 if(idm[nd[k].id]==1)
118 {
119 // cout<<nd[k].id<<endl;
120 int len=nd[k].ed-nd[k].st+1;
121 nd[k].st=x;
122 nd[k].ed=x+len-1;
123 x=nd[k].ed+1;
124 // cout<<nd[k].st<<nd[k].ed<<endl;
125 }
126 }
127 }
128 }
129 return 0;
130 }
codeforces 7B的更多相关文章
- python爬虫学习(5) —— 扒一下codeforces题面
上一次我们拿学校的URP做了个小小的demo.... 其实我们还可以把每个学生的证件照爬下来做成一个证件照校花校草评比 另外也可以写一个物理实验自动选课... 但是出于多种原因,,还是绕开这些敏感话题 ...
- 【Codeforces 738D】Sea Battle(贪心)
http://codeforces.com/contest/738/problem/D Galya is playing one-dimensional Sea Battle on a 1 × n g ...
- 【Codeforces 738C】Road to Cinema
http://codeforces.com/contest/738/problem/C Vasya is currently at a car rental service, and he wants ...
- 【Codeforces 738A】Interview with Oleg
http://codeforces.com/contest/738/problem/A Polycarp has interviewed Oleg and has written the interv ...
- CodeForces - 662A Gambling Nim
http://codeforces.com/problemset/problem/662/A 题目大意: 给定n(n <= 500000)张卡片,每张卡片的两个面都写有数字,每个面都有0.5的概 ...
- CodeForces - 274B Zero Tree
http://codeforces.com/problemset/problem/274/B 题目大意: 给定你一颗树,每个点上有权值. 现在你每次取出这颗树的一颗子树(即点集和边集均是原图的子集的连 ...
- CodeForces - 261B Maxim and Restaurant
http://codeforces.com/problemset/problem/261/B 题目大意:给定n个数a1-an(n<=50,ai<=50),随机打乱后,记Si=a1+a2+a ...
- CodeForces - 696B Puzzles
http://codeforces.com/problemset/problem/696/B 题目大意: 这是一颗有n个点的树,你从根开始游走,每当你第一次到达一个点时,把这个点的权记为(你已经到过不 ...
- CodeForces - 148D Bag of mice
http://codeforces.com/problemset/problem/148/D 题目大意: 原来袋子里有w只白鼠和b只黑鼠 龙和王妃轮流从袋子里抓老鼠.谁先抓到白色老鼠谁就赢. 王妃每次 ...
随机推荐
- SW3518中文规格书
SW3518 是一款高集成度的多快充协议双口充电芯片, 支持 A+C 口任意口快充输出, 支持双口独立限流. 其集成了 5A 高效率同步降压变换器, 支持 PPS/PD/QC/AFC/FCP/SCP/ ...
- three.js cannon.js物理引擎地形生成器和使用指针锁定控件
今天郭先生说一说使用cannon.js物理引擎绘制地形和使用指针锁定控件.效果如下图.线案例请点击博客原文. 这里面的生成地形的插件和指针锁定控件也是cannon.js的作者schteppe封装的,当 ...
- 飞机大战(1)--添加logo和加载动画
注:以下代码都是用scratch 3.0版本编写 素材链接: 链接:https://pan.baidu.com/s/1sXqeZVuFgVTYT0OtqxXilw 提取码:1126 一.背景添加 导入 ...
- 前端面试之HTTP状态码!
前端面试之HTTP协议的东西! 一次HTTP请求的流程! HTTP 状态码 成功响应(200–299) 状态码 含义 200 请求成功 201 该请求已成功,并因此创建了一个新的资源.这通常是在POS ...
- (16)-Python3之--集合(set)操作
1.定义 集合的关键字:set 集合主要作用: 去重,把一个列表变成集合,就自动去重了 关系测试,测试两组数据之前的交集.差集.并集等关系 集合用大括号{}表示,元素间用逗号分隔. 建立集合类型用{} ...
- C#高级编程第11版 - 第八章 索引
[1]8.1 引用方法 1.委托是指向方法的.NET地址变量. 2.委托是类型安全的类,定义了返回类型和参数类型.委托类不单单只包含一个方法引用,它也可以保存多个方法的引用. 3.Lambda表达式直 ...
- Redis持久化之父子进程与写时复制
之所以将Linux底层的写时复制技术放在Redis篇幅下,是因为Redis进行RDB持久化时,BGSAVE(后面称之为"后台保存")会开辟一个子进程,将数据从内存写进磁盘,这儿我产 ...
- 2 安装部署flume
本文对flume进行安装部署 flume是什么?传送门:https://www.cnblogs.com/zhqin/p/12230301.html 0.要安装部署在日志所在的服务器,或者把日志发送到日 ...
- JAVA中关于基本数据和引用数据参数传递过程
基本数据和引用数据参数传递过程 案例1:判断程序的输出结果 class Demo{ public static void main(String[] atgs){ int x =4; show(x); ...
- loj10008家庭作业
题目描述 老师在开学第一天就把所有作业都布置了,每个作业如果在规定的时间内交上来的话才有学分.每个作业的截止日期和学分可能是不同的.例如如果一个作业学分为10 ,要求在6 天内交,那么要想拿到这 10 ...