#P50942. 「CEOI2012」工作规划

「CEOI2012」工作规划

题目描述

译自 CEOI 2012 Day1 T1「Job Scheduling

CEOI 在 NN 天内收到了 MM 个任务,每个任务需要 1 台机器工作 1 天来完成。CEOI 有很多台机器,每台机器一天只能完成一个任务。 CEOI 要求每个任务最多只能推迟 DD 天完成。换言之,如果一个客户在第 SS 天提交了一个任务,CEOI 必须在第 S+DS+D 天之前完成它。

请你写程序求出每个任务最多推迟 DD 天的前提下,最少需要多少台机器才能按要求完成所有任务。

输入格式

第一行输入包含三个整数,N(1N100)N(1\leq N\leq100) 是 CEOI 接受任务的天数,D(0D<N)D(0\leq D<N) 是每个任务最多可以推迟的天数。MM (1M106)(1 \leq M \leq 10^6) 是任务的个数。

第二行是 MM 个被空格分隔的整数。第 ii 个数代表收到第 ii 个任务时间。第 NDN-D 天之后均没有任务。所有的任务按照输入顺序从 11NN 依次编号。

输出格式

第一行输出一个整数,即能完成任务的最少机器数。

第二行到第 N+1N+1 行,依次输出每天完成的任务,以 00 结尾。 如果有多组解,输出任意一组即可。

样例

8 2 12
1 2 4 2 1 3 5 6 2 3 6 4
2
5 1 0
9 4 0
2 10 0
6 12 0
3 7 0
11 8 0
0
0

数据范围与提示

对于 50%50\% 的测试点,M105M ≤ 10^5
对于所有测试点,1N100,1\leq N\leq100, 0D<N,0\leq D<N, 1M1061 \leq M \leq 10^6

如果第一行输出正确,你将会得到该测试点 40%40\% 的分数。