#1611. 磁盘碎片整理

磁盘碎片整理

题目描述

由于最高安全性考虑,司令部采用了特殊的安全操作系统。该系统采用一个特殊的文件系统。在这个文件系统中所有磁盘空间都被分成了相同尺寸的N\red {N}块,用整数1\red {1}N\red {N}标识。每个文件占用磁盘上任意区域的一块或多块存储区,未被文件占用的存储块被认为是可使用的。如果文件存储在磁盘上自然连续的存储块中,则能被以最快的速度读出。

因为磁盘是匀速转动的,所以存取上面不同的存储块需要的时间也不同。读取磁盘开头处的存储块比读取磁盘结尾处的存储块快。根据以上现象,我们事先将文件按其存取频率的大小用整数1\red {1}K\red {K}标识。按文件在磁盘上的最佳存储方法,1\red {1}号文件将占用12S1 \red {1,2,…,S_1~}的存储块,2\red {2}号文件将占用S1 +1S1 +2S1 +S2 \red {S _1~ +1,S_1~ +2,…,S_1~ +S_2~}的存储块,以此类推(Si \red {S_i~}是被第i\red {i}个文件占用的存储块的个数)。为了将文件以最佳形式存储在磁盘上,需要执行存储块移动操作。一个存储块移动操作包括从磁盘上读取一个被占用的存储块至内存并将它写入其他空的存储块,然后宣称前一个存储块被释放,后一个存储块被占用。

本程序的目的是通过执行最少次数的存储块移动操作,将文件按最佳方式存储到磁盘上,注意同一个文件的存储块在移动之后其相对次序不可改变。

输入格式

每个磁盘说明的第一行包含两个用空格隔开的整数N\red {N}K1=K=N=100000\red {K,1〈=K〈=N〈=100000},接下来的K\red {K}行每行说明一个文件,对第i\red {i}个文件的说明是这样的:首先以整数Si \red {S_i~}开头,表示第i\red {i}个文件的存储块数量,1=Si 〈=NK\red {1〈=S _i~ 〈=N-K},其后跟Si \red {S_i~}个整数,每个整数之间用空格隔开,表示该文件按自然顺序在磁盘上占用的存储块的标识。所有这些数都介于1\red {1}N\red {N}之间,包括1\red {1}N\red {N}。一个磁盘说明中所有存储块的标识都是不同的,并且该盘至少有一个空的存储块。

输出格式

对于每一个磁盘说明,只需输出一行句子“We need M move operations”M\red {M}表示将文件按最佳方式存储到磁盘上所需进行的最少存储块移动操作次数。否则输出”No optimization needed.”

样例

输入样例

2099 399

499 299 399 1199 1299

199 799
399 1899 599 1099

输出样例

We need 10000 move operations.