class Solution {
public:
int f[25][2010];//体积范围从-1000~1000
int findTargetSumWays(vector<int>& nums, int target) {
int n=nums.size(),offset=1000;//价值总和不超过1000,因此偏移量设置1000即可
f[0][0+offset]=1;
for(int i=1;i<=n;i++)
for(int j=-1000;j<=1000;j++)
{
if(j-nums[i-1]>=-1000)//保证下标在合法范围
f[i][j+offset]+=f[i-1][j-nums[i-1]+offset];
if(j+nums[i-1]<=1000)//保证下标在合法范围
f[i][j+offset]+=f[i-1][j+nums[i-1]+offset];
}
return f[n][target+offset];
}
};
标签:nums,int,目标,offset,494,size,1000
From: https://www.cnblogs.com/tangxibomb/p/17319943.html