#A0046. 发送快递
发送快递
题目描述
小华有 本不同的书(编号为),重量分别是公斤(重量可以相同)。他想把这些书以快递的方式发给自己的好朋友,要求每个包裹的重量不能超过 公斤(可以等于 公斤),并且小华想把其中一些书(一组书,用书的编号给出来)放在一个包裹里,应该如何打包才能使得快递件数最少。
输入描述 第一行,包含两个整数 ,之间用一个空格隔开,分别表示书的数量和快递包裹的最大重量。 第二行 个整数 ,表示 本书的重量,每两个整数之间用一个空格隔开。 第三行一个整数,表示一共有 组书(每组书需要打包在一起)。如果,则无此限制。数据保证每组书的重量不超过。 第四行开始共 行,每行若干个整数,表示必须放在一个包裹里的书编号,每两个整数之间用一个空格隔开。
输出描述
输出文件一行,一个整数,即快递最少件数。
输入样例1
5 10
8 4 8 2 5
0
输出样例1
3
输入输出样例1 说明
第 本和第 本打包,重量是 公斤。第 本和第 本打包,重量是 公斤。第 本单独打包,重量是 公斤。所以一共 件快递。
输入样例2
10 80
49 11 44 18 28 24 19 10 27 29
2
1 5
4 8 2
输出样例2
4
输入输出样例2 说明
第 本和第 本打包,第 本、第 本、第 本和第 本打包,第 本和第 本打包,第 本和第 本打包。所以一共 件快递。
数据范围
对于的数据, 的值保证有解。 对于的数据,的值保证有解。