LeetCode 377. Combination Sum IV

原題連接在這裏:https://leetcode.com/problems/combination-sum-iv/html

題目:post

Given an integer array with all positive numbers and no duplicates, find the number of possible combinations that add up to a positive integer target.url

Example:spa

nums = [1, 2, 3]
target = 4

The possible combination ways are:
(1, 1, 1, 1)
(1, 1, 2)
(1, 2, 1)
(1, 3)
(2, 1, 1)
(2, 2)
(3, 1)

Note that different sequences are counted as different combinations.

Therefore the output is 7.

Follow up:
What if negative numbers are allowed in the given array?
How does it change the problem?
What limitation we need to add to the question to allow negative numbers?code

題解:htm

Let dp[i] denotes possible combinations that add up to i.blog

Set some examples and find out that if there is nubmer smaller than i that i - num == j (num is the number of nums), then accumlate ways added up to j into dp[i].leetcode

Initialize dp[0] =1, then all the numbers in nums will be initialized to 1 when it comes to dp[num-num].get

答案dp[target].it

If there is negative numbers allowed, there could be infinite possibilities. 

e.g. target = 1, there is [-1, 1] in nums, then the possible ways could be -1+1+1, -1-1+1+1+1 ...

If allowing negative numbers, there can't be any combiantion of neigatie numers + any combiantion of positive numbers == 0. 

Time Complexity: O(target*nums.length).

Space: O(target).

AC Java:

 1 class Solution {
 2     public int combinationSum4(int[] nums, int target) {       
 3         int [] dp = new int[target+1];
 4         dp[0] = 1;
 5         
 6         for(int i = 1; i<=target; i++){
 7             for(int j = 0; j<nums.length; j++){
 8                 if(i>=nums[j]){
 9                     dp[i] += dp[i-nums[j]];
10                 }
11             }
12         }
13         return dp[target];
14     }
15 }

跟着Combination SumCombination Sum IICombination Sum III.

相似Climbing Stairs.

相關文章
相關標籤/搜索