题目大意就是求讲数据1…N分成两组,使得两组中元素的和加起来相等,求这样分组的情况数
可以利用递推的方法求该题的解,注意:f(k,a)=(f(k-1,a+k)+f(k-1,a-k))/2;其中f(k,a)表示讲1…k元素分两组,使第一组比第二组多a;
因为k只可能分到第一组或第二组这两种情况,如果k加到第一组后使得第一组比第二组多a,则要原来的分组中第一组比第二组多a-k
同理如果k加到第二组后使得第一组比第二组多a,则要原来的分组中第一组比第二组多a+k。
因为交换两组元素后也满足条件,而只算一个解,故后面要除2;
很显然题目要求的是f(N,0);
为节省递推时间,可使用记忆化搜索,考虑到数据不大,又a有正负之分,可加数组适当开大。
数据分析:N最大为39,32位整数可能存不下,故要使用64位扩展,故要将数据声明为long long .因为使用的是记忆化搜索,很大程度上减少了重复搜索的情况,时间复杂度为O(n^3),远优于O(2^n),不会超时.。
1 | /* |