JB TAK FODEGA NHI .... TB TK CHODEGA NHI .... (MAANG)
DPL14 Subset Sum Equals to Target 🔥
You are given an array/list ‘ARR’ of ‘N’ positive integers and an integer ‘K’. Your task is to check if there exists a subset in ‘ARR’ with a sum equal to ‘K’.
Note: Return true if there exists a subset with sum equal to ‘K’. Otherwise, return false.
what a Subsequence/Subset?
A subset/subsequence is a contiguous or non-contiguous part of an array, where elements appear in the same order as the original array.
For example, for the array: [2,3,1] , the subsequences will be [{2},{3},{1},{2,3},{2,1},{3,1},{2,3,1}] but {3,2} is not a subsequence because its elements are not in the same order as the original array.
data:image/s3,"s3://crabby-images/068d1/068d1834b1b0edc5c1561d2bc8f8da7480dfc399" alt=""
In this Question first thing Comes into the My Mind is Generate all the Possible Subsecquance and check if any sum(subset) == k or not
I Have Two Option for this Question
But in this Problem we Just Required the Only One Subset no Need to Check All the Subsetst thats why I go with the Recursion Approch
Recursice Approch
Steps to form the Recursive SolutionStep 1: Express the problem in terms of indexes.
So, we can say that initially, we need to fun(n-1, target) which means that we need to find whether there exists a subsequence in the array from index 0 to n-1, whose sum is equal to the target. Similarly, we can generalize it for any index ind as follows:
data:image/s3,"s3://crabby-images/c5749/c5749d6535f1961f03353b239ea9d6e77ae1eb29" alt=""
The Recursive Function is
data:image/s3,"s3://crabby-images/008b7/008b7ad4a11749abbf24ba9a98c929498483b451" alt=""
Step 2: Try out all possible choices at a given index.
We need to generate all the subsequences. We will use the pick/non-pick technique as discussed in, That we All Ready Learn in the Recursion Series.
We have two choices:Note: We will consider the current element in the subsequence only when the current element is less or equal to the target.
data:image/s3,"s3://crabby-images/f426d/f426dc4c31c399f261a169ff9ae2d1341cca3ba5" alt=""
The final pseudocode after steps 1, 2, and 3:
data:image/s3,"s3://crabby-images/6682b/6682b63ecdc01a6bdd0ca7070c5597bf7bf71edb" alt=""
Recursion Tree
data:image/s3,"s3://crabby-images/e8efd/e8efd67168eb3514d22a2e9b00bf8578baec7065" alt=""
data:image/s3,"s3://crabby-images/7a028/7a028b8b779c55305fa18107b868fc99110f5332" alt="".png)
data:image/s3,"s3://crabby-images/dc1d5/dc1d59612802a754973f7336090f266a4fcb5153" alt="".png)
Sb Mai He Kru ...
Khud Bhi Kr le Khuch ..... Nalayk
Time & Space Complexity
Time Complexity: O(2^N)Reason: Exponential Time we find out the all the Possible Path
Space Complexity: O(N)
Reason: We are using a recursion stack space(O(N))
Memoization Approch
If we observe in the recursion tree, we will observe a many number of overlapping subproblems. Therefore the recursive solution can be memoized for to reduce the time complexity.
data:image/s3,"s3://crabby-images/e8efd/e8efd67168eb3514d22a2e9b00bf8578baec7065" alt=""
Steps to convert Recursive code to memoization solution:
data:image/s3,"s3://crabby-images/b473e/b473eca749ec780dfc2148a2f827ee814b021bcc" alt="".png)
data:image/s3,"s3://crabby-images/e0361/e036168401927fa060fe5eb1ebac4993943bec9f" alt="".png)
Sb Mai He Kru ...
Khud Bhi Kr le Khuch ..... Nalayk
Time & Space Complexity
Time Complexity:O(N*K)Reason: There are N*K states therefore at max ‘N*K’ new problems will be solved.
Space Complexity: O(N*K) + O(N)
Reason: We are using a recursion stack space(O(N)) and a 2D array ( O(N*K)).
Tabulation Approch
Tabulation is a ‘bottom-up’ approach where we start from the base case and reach the final answer that we want and Memoization is the Top-down Approch.In Tabulation Approch We Just Creat a DP Array Same as Memoization and Simply Convert the Recurance Relation into the form of the Looping
Steps to convert Recursive Solution to Tabulation one.data:image/s3,"s3://crabby-images/a635a/a635a1e35ba91e60fce9a15faa3a5dda9800d723" alt=""
data:image/s3,"s3://crabby-images/9844f/9844f358021cfa418d415cec0cddf0668cbd7f1a" alt=""
data:image/s3,"s3://crabby-images/980d4/980d4a69a980bb461446213d1aa4bd9367532fdd" alt=""
data:image/s3,"s3://crabby-images/7bc87/7bc87324e519f247502deb359464ef82722f4dad" alt="".png)
data:image/s3,"s3://crabby-images/ac9d9/ac9d9104644aa8c066de3e232ba489600fbbfba6" alt="".png)
Sb Mai He Kru ...
Khud Bhi Kr le Khuch ..... Nalayk
Time & Space Complexity
Time Complexity: O(N*K)Reason:There are 2 nested loops
Space Complexity: O(N*K)
Reason: We are using an external array of size ‘N*K’’.
Space Optimization
If we closelly Observed if any Tabulation Approch we used the Some Limited Stuff like: dp[ind][target] = dp[ind-1][target] || dp[ind-1][target-arr[ind]] for the finding the our ans then definetly here Spaced Optimization is Possible in that types of Problems. Always Remember
Golden Ruledata:image/s3,"s3://crabby-images/6514c/6514cebc27cfc38ed42667e1329cc453e52ca92c" alt=""
data:image/s3,"s3://crabby-images/e4790/e4790060509f73b25804aee801b320f05d7aae19" alt="".png)
data:image/s3,"s3://crabby-images/68914/68914f167a37aee5314c5bd510575a90d91a1e0f" alt="".png)
Sb Mai He Kru ...
Khud Bhi Kr le Khuch ..... Nalayk
Time & Space Complexity
Time Complexity:O(N*K)Reason: There are three 2 nested loops
Space Complexity: O(K)
Reason: We are using an external array of size ‘K+1’ to store only one row.