LeetCode 494. 目標(biāo)和

每天一道DP防止抑郁


題目描述:

給定一個非負(fù)整數(shù)數(shù)組炉旷,a1, a2, ..., an, 和一個目標(biāo)數(shù)码邻,S。現(xiàn)在你有兩個符號 + 和 -镶奉。對于數(shù)組中的任意一個整數(shù),你都可以從 + 或 -中選擇一個符號添加在前面溪王。

返回可以使最終數(shù)組和為目標(biāo)數(shù) S 的所有添加符號的方法數(shù)腮鞍。

示例 1:

輸入: nums: [1, 1, 1, 1, 1], S: 3
輸出: 5
解釋:

-1+1+1+1+1 = 3
+1-1+1+1+1 = 3
+1+1-1+1+1 = 3
+1+1+1-1+1 = 3
+1+1+1+1-1 = 3

一共有5種方法讓最終目標(biāo)和為3。


首先莹菱,我們來推導(dǎo)幾個公式移国。
設(shè)nums數(shù)組中添加負(fù)號的數(shù)的和為SumN,nums數(shù)組中添加正號的數(shù)的和為SumP道伟,數(shù)組的和為Sum迹缀。
由題意,我們可以得出:
SumP - SumN = S ==> SumP + SumP = S + SumN + SumP ==> 2 * SumP = S + Sum ==> SumP = (Sum + S) / 2蜜徽。

所以這道題轉(zhuǎn)化為從nums數(shù)組中選擇數(shù)字求和祝懂,要求這個和等于Sum加上S除以二。求有總共有多少種情況拘鞋。
這個問題進(jìn)而轉(zhuǎn)化為子集合問題砚蓬,所以可以用0-1背包問題來解決這道題目。
狀態(tài)轉(zhuǎn)移方程為:dp[i] = dp[i] + dp[i - nums[i]] (dp[i] : 從nums中取數(shù)盆色,使得這些數(shù)字的和為i的取法)


代碼如下:

class Solution {
    public int findTargetSumWays(int[] nums, int S) {
        int sum = 0;
        for (int i : nums) {
            sum += i;
        }
        /*
            剪枝灰蛙。如果全部選正號的和都小于S的話,怎么組合都達(dá)不到S
         */
        if (sum < S || (S + sum) % 2 == 1) {
            return 0;
        }
        int target = (S + sum) / 2;
        int[] dp = new int[target + 1];//dp[i]: 從nums中取數(shù)隔躲,使得這些數(shù)字的和為i的取法
        dp[0] = 1;
        for (int num : nums) {
            for (int i = target; i >= num; i--) {
                dp[i] += dp[i - num];
            }
        }
        return dp[target];
    }
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末摩梧,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子宣旱,更是在濱河造成了極大的恐慌仅父,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,816評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件浑吟,死亡現(xiàn)場離奇詭異笙纤,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)组力,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,729評論 3 385
  • 文/潘曉璐 我一進(jìn)店門粪糙,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人忿项,你說我怎么就攤上這事。” “怎么了轩触?”我有些...
    開封第一講書人閱讀 158,300評論 0 348
  • 文/不壞的土叔 我叫張陵寞酿,是天一觀的道長。 經(jīng)常有香客問我脱柱,道長伐弹,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,780評論 1 285
  • 正文 為了忘掉前任榨为,我火速辦了婚禮惨好,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘随闺。我一直安慰自己日川,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 65,890評論 6 385
  • 文/花漫 我一把揭開白布矩乐。 她就那樣靜靜地躺著龄句,像睡著了一般。 火紅的嫁衣襯著肌膚如雪散罕。 梳的紋絲不亂的頭發(fā)上分歇,一...
    開封第一講書人閱讀 50,084評論 1 291
  • 那天,我揣著相機(jī)與錄音欧漱,去河邊找鬼职抡。 笑死,一個胖子當(dāng)著我的面吹牛误甚,可吹牛的內(nèi)容都是我干的缚甩。 我是一名探鬼主播,決...
    沈念sama閱讀 39,151評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼靶草,長吁一口氣:“原來是場噩夢啊……” “哼蹄胰!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起奕翔,我...
    開封第一講書人閱讀 37,912評論 0 268
  • 序言:老撾萬榮一對情侶失蹤裕寨,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后派继,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體宾袜,經(jīng)...
    沈念sama閱讀 44,355評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,666評論 2 327
  • 正文 我和宋清朗相戀三年驾窟,在試婚紗的時候發(fā)現(xiàn)自己被綠了庆猫。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,809評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡绅络,死狀恐怖月培,靈堂內(nèi)的尸體忽然破棺而出嘁字,到底是詐尸還是另有隱情,我是刑警寧澤杉畜,帶...
    沈念sama閱讀 34,504評論 4 334
  • 正文 年R本政府宣布纪蜒,位于F島的核電站,受9級特大地震影響此叠,放射性物質(zhì)發(fā)生泄漏纯续。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 40,150評論 3 317
  • 文/蒙蒙 一灭袁、第九天 我趴在偏房一處隱蔽的房頂上張望猬错。 院中可真熱鬧,春花似錦茸歧、人聲如沸倦炒。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,882評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽析校。三九已至,卻和暖如春铜涉,著一層夾襖步出監(jiān)牢的瞬間智玻,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,121評論 1 267
  • 我被黑心中介騙來泰國打工芙代, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留吊奢,地道東北人。 一個月前我還...
    沈念sama閱讀 46,628評論 2 362
  • 正文 我出身青樓纹烹,卻偏偏與公主長得像页滚,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子铺呵,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,724評論 2 351

推薦閱讀更多精彩內(nèi)容