题目大意:
一个天平,分别给出c个位置和g个钩码的质量,求解所有钩码全部放上时有多少种使天平平衡的方案,输出方案数。
样例输入:
2 4// 两个位置可放钩码,共四个钩码;
-2 3//两个位置为平衡点左边(感性理解一下)第二格和右边第三格;
3 4 5 8//四个钩码的质量;
样例输出:
2//有两种方案;
样例解释:
把四个钩码按顺序标号为1,2,3,4,则:
方案一:“-2”位置放1,2,3号钩码,“3”位置放4号钩码。
//2*(3+4+5)=3*8;
方案二:“-2”位置放2,4号钩码,“3”位置放1,3号钩码。
//2*(4+8)=3*(3+5);
数据范围:
2<=c<=20,2<=g<=20,天平长度[-15,15],钩码质量[1,25]。
解题思路:
首先,要了解力矩平衡:动力臂乘动力等于阻力臂乘阻力。
然后考虑算法,朴素的枚举会爆炸。
由于每放一个钩码在某一位置上的状态可由某前一状态得到,所以自然想到动态规划。
dp[i][j]代表放上前i个钩码后天平偏移量为j的方案数,则