标签:else bsp turn noi border wrap 剪枝 等级 put
1999年NOIP全国联赛提高组
给定一个信封,最多只允许粘贴N张邮票,计算在给定K(N+K≤40)种邮票的情况下(假定所有的邮票数量都足够),如何设计邮票的面值,能得到最大值MAX,使在1~MAX之间的每一个邮资值都能得到。
例如,N=3,K=2,如果面值分别为1分、4分,则在1分~6分之间的每一个邮资值都能得到(当然还有8分、9分和12分);如果面值分别为1分、3分,则在1分~7分之间的每一个邮资值都能得到。可以验证当N=3,K=2时,7分就是可以得到的连续的邮资最大值,所以MAX=7,面值分别为1分、3分。
N和K
每种邮票的面值,连续最大能到的面值数。数据保证答案唯一。
3 2
1 3
MAX=7
思路:
先用dfs+剪枝找出所以符合要求的邮票种类,再用dp(01背包)。
看代码:
#include <iostream> |
标签:else bsp turn noi border wrap 剪枝 等级 put
原文地址:http://www.cnblogs.com/lhlacm/p/7978943.html