1 解题思路
leetcode才出来的时候,测试用例比较简单,所以我之前用的是暴力法,而且AC了,后面有人和我说没法通过了,所以后面我重新做了下,[并且参照了他的思路(](http://blog.csdn.net/liuyue910828/article/details/52792357)
我多了注释,做个广告):
现在用了背包去解决的,首先:
1、依然数组的和必须要是偶数,否则无法划分,共计n个数,这里价值value/weight都等于nums
2、将问题转化为背包问题,即取前I个数(物品),和体积j下,dp[i][j]的最大值
dp[i][j]=max{ dp[i-1][j], dp[i-1][j-nums[i]]+nums[i] }。
3、这样dp[n][sum/2] 如果等于sum/2 就证明用了这n个数下,正好能加出一个sum/2,所以就自然而然的通过了
PS:最后,我突然觉得其实都没必要用二位数组了。。。
原来的暴力解法:
其实所谓的对半分,就是一个数组划分成两部分,两部分的和一样
所以思路:
1、首先数组的和必须要是偶数,否则无法划分
2、直接暴力的DFS+回溯,即查找是否有1/2与数组和的存在
3、我是用了排序后,DFS时可以剪枝的方式
4、关于3中排序的开销是否值得,大家自己测试
总之,是一个暴力而简单的解法
#2 原题
Given a