494. 目标和

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];
    }
};
posted @   穿过雾的阴霾  阅读(14)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
点击右上角即可分享
微信分享提示