Given a number N, the task is to count the combinations of K numbers from 1 to N having a sum equal to N, with duplicates allowed.
Example:
Input: N = 7, K = 3
Output:15
Explanation:The combinations which lead to the sum N = 7 are: {1, 1, 5}, {1, 5, 1}, {5, 1, 1}, {2, 1, 4}, {1, 2, 4}, {1, 4, 2}, {2, 4, 1}, {4, 1, 2}, {4, 2, 1}, {3, 1, 3}, {1, 3, 3}, {3, 3, 1}, {2, 2, 3}, {2, 3, 2}, {3, 2, 2}Input: N = 5, K = 5
Output: 1
Explanation: {1, 1, 1, 1, 1} is the only combination.
Naive Approach: This problem can be solved using recursion and then memoising the result to improve time complexity. To solve this problem, follow the below steps:
- Create a function, say countWaysUtil which will accept four parameters that are N, K, sum, and dp. Here N is the sum that K elements are required to have, K is the number of elements consumed, sum is the sum accumulated till now and dp is the matrix to memoise the result. This function will give the number of ways to get the sum in K numbers.
- Now initially call countWaysUtil with arguments N, K, sum=0 and dp as a matrix filled with all -1.
- In each recursive call:
- Check for the base cases:
- If the sum is equal to N and K become 0, then return 1.
- If the sum exceeds N and K is still greater than 0, then return 0.
- Now, run a for loop from 1 to N, to check the result for each outcome.
- Sum all the results in a variable cnt and return cnt after memoising.
- Check for the base cases:
- Print the answer according to the above observation.
Below is the implementation of the above approach:
C++
// C++ program for the above approach Â
#include <bits/stdc++.h> using namespace std; Â
// Function to count // all the possible combinations // of K numbers having sum equals to N int countWaysUtil( int N, int K, int sum, Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â vector<vector< int > >& dp) { Â
    // Base Cases     if (sum == N and K == 0) {         return 1;     } Â
    if (sum >= N and K >= 0) {         return 0;     } Â
    if (K < 0) {         return 0;     } Â
    // If the result is already memoised     if (dp[sum][K] != -1) {         return dp[sum][K];     } Â
    // Recursive Calls     int cnt = 0;     for ( int i = 1; i <= N; i++) {         cnt += countWaysUtil(             N, K - 1,             sum + i, dp);     } Â
    // Returning answer     return dp[sum][K] = cnt; } Â
void countWays( int N, int K) { Â Â Â Â vector<vector< int > > dp(N + 1, Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â vector< int >( Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â K + 1, -1)); Â Â Â Â cout << countWaysUtil(N, K, 0, dp); } Â
// Driver Code int main() { Â Â Â Â int N = 7, K = 3; Â Â Â Â countWays(N, K); } |
Java
// Java implementation for the above approach class GFG { Â
    // Function to count     // all the possible combinations     // of K numbers having sum equals to N     static int countWaysUtil( int N, int K, int sum,                              int [][] dp)     { Â
        // Base Cases         if (sum == N && K == 0 ) {             return 1 ;         } Â
        if (sum >= N && K >= 0 ) {             return 0 ;         } Â
        if (K < 0 ) {             return 0 ;         } Â
        // If the result is already memoised         if (dp[sum][K] != - 1 ) {             return dp[sum][K];         } Â
        // Recursive Calls         int cnt = 0 ;         for ( int i = 1 ; i <= N; i++) {             cnt += countWaysUtil(N, K - 1 , sum + i, dp);         } Â
        // Returning answer         return dp[sum][K] = cnt;     } Â
    static void countWays( int N, int K)     {         int [][] dp = new int [N + 1 ][K + 1 ];         for ( int i = 0 ; i < N + 1 ; i++) {             for ( int j = 0 ; j < K + 1 ; j++) { Â
                dp[i][j] = - 1 ;             }         }         System.out.print(countWaysUtil(N, K, 0 , dp));     } Â
    // Driver Code     public static void main(String[] args)     {         int N = 7 , K = 3 ;         countWays(N, K);     } } Â
// This code is contributed by ukasp. |
Python3
# Python3 program for the above approach Â
# Function to count all the possible # combinations of K numbers having # sum equals to N def countWaysUtil(N, K, sum , dp): Â
    # Base Cases     if ( sum = = N and K = = 0 ):         return 1 Â
    if ( sum > = N and K > = 0 ):         return 0 Â
    if (K < 0 ):         return 0 Â
    # If the result is already memoised     if (dp[ sum ][K] ! = - 1 ):         return dp[ sum ][K] Â
    # Recursive Calls     cnt = 0     for i in range ( 1 , N + 1 ):         cnt + = countWaysUtil(N, K - 1 , sum + i, dp) Â
    # Returning answer     dp[ sum ][K] = cnt     return dp[ sum ][K] Â
def countWays(N, K): Â Â Â Â Â Â Â Â Â dp = [[ - 1 for _ in range (K + 1 )] Â Â Â Â Â Â Â Â Â Â Â Â Â Â for _ in range (N + 1 )] Â Â Â Â print (countWaysUtil(N, K, 0 , dp)) Â
# Driver Code if __name__ = = "__main__" : Â
    N = 7     K = 3          countWays(N, K) Â
# This code is contributed by rakeshsahni |
C#
// C# implementation for the above approach using System; class GFG { Â Â Â Â Â // Function to count // all the possible combinations // of K numbers having sum equals to N static int countWaysUtil( int N, int K, int sum, Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â int [,]dp) { Â
    // Base Cases     if (sum == N && K == 0) {         return 1;     } Â
    if (sum >= N && K >= 0) {         return 0;     } Â
    if (K < 0) {         return 0;     } Â
    // If the result is already memoised     if (dp[sum, K] != -1) {         return dp[sum, K];     } Â
    // Recursive Calls     int cnt = 0;     for ( int i = 1; i <= N; i++) {         cnt += countWaysUtil(             N, K - 1,             sum + i, dp);     } Â
    // Returning answer     return dp[sum, K] = cnt; } Â
static void countWays( int N, int K) { Â Â Â Â int [,]dp = new int [N + 1, K + 1]; Â Â Â Â for ( int i = 0; i < N + 1; i++) { Â Â Â Â Â Â Â Â for ( int j = 0; j < K + 1; j++) { Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â Â dp[i, j] = -1; Â Â Â Â Â Â Â Â } Â Â Â Â } Â Â Â Â Console.Write(countWaysUtil(N, K, 0, dp)); } Â
// Driver Code public static void Main() { Â Â Â Â int N = 7, K = 3; Â Â Â Â countWays(N, K); } } Â
// This code is contributed by Samim Hossain Mondal. |
Javascript
<script> // Javascript program for the above approach Â
// Function to count // all the possible combinations // of K numbers having sum equals to N function countWaysUtil(N, K, sum, dp) { Â
    // Base Cases     if (sum == N && K == 0) {         return 1;     } Â
    if (sum >= N && K >= 0) {         return 0;     } Â
    if (K < 0) {         return 0;     } Â
    // If the result is already memoised     if (dp[sum][K] != -1) {         return dp[sum][K];     } Â
    // Recursive Calls     let cnt = 0;     for (let i = 1; i <= N; i++) {         cnt += countWaysUtil(             N, K - 1,             sum + i, dp);     } Â
    // Returning answer     return dp[sum][K] = cnt; } Â
function countWays(N, K) { Â Â Â Â let dp = new Array(N + 1).fill(0).map(() => new Array(K + 1).fill(-1)) Â Â Â Â document.write(countWaysUtil(N, K, 0, dp)); } Â
// Driver Code let N = 7, K = 3; countWays(N, K); Â
// This code is contributed by saurabh_jaiswal. </script> |
15
Time Complexity: O(N*K)
Space Complexity: O(N*K)
Efficient Approach:Â This problem can also be solved using the binomial theorem. As the required sum is N with K elements, so suppose the K numbers are:
a1 + a2 + a3 + a4 + …….. + aK = N
According to the standard principle of partitioning in the binomial theorem, the above equation has a solution which is N+K-1CK-1, where K>=0.
But in our case, K>=1.
So, therefore N should be substituted with N-K and the equation becomes N-1CK-1
Below is the implementation of the above approach:
C++
// C++ program for the above approach #include <iostream> using namespace std; Â
// Method to find factorial of given number int factorial( int n) { Â Â Â Â if (n == 0) Â Â Â Â Â Â Â Â return 1; Â Â Â Â Â Â Â Â Â Â Â Â Â return n * factorial(n - 1); } Â
// Function to count all the possible // combinations of K numbers having // sum equals to N int totalWays( int N, int K) {          // If N<K     if (N < K)         return 0;          // Storing numerator     int  n1 = factorial(N - 1);          // Storing denominator     int n2 = factorial(K - 1) * factorial(N - K);     int ans = (n1 / n2);          // Returning answer     return ans; } Â
// Driver code int main() { Â Â Â Â int N = 7; Â Â Â Â int K = 3; Â Â Â Â int ans = totalWays(N, K); Â Â Â Â Â Â Â Â Â cout << ans; Â Â Â Â Â Â Â Â Â return 0; } Â
// This code is contributed by Shubham Singh |
C
// C Program for the above approach #include <stdio.h> Â
 // method to find factorial of given number  int factorial( int n)  {     if (n == 0)       return 1; Â
    return n*factorial(n - 1);  } Â
 // Function to count  // all the possible combinations  // of K numbers having sum equals to N  int totalWays( int N, int K) { Â
    // If N<K     if (N < K)       return 0; Â
    // Storing numerator     int  n1 = factorial(N - 1); Â
    // Storing denominator     int n2 = factorial(K - 1)*factorial(N - K);     int ans = (n1/n2); Â
    // Returning answer     return ans;  } Â
  // Driver method   int main()   { Â
    int N = 7;     int K = 3;     int ans = totalWays(N, K);     printf ( "%d" ,ans);     return 0;   }    // This code is contributed by Shubham Singh |
Java
// Java Program for the above approach class Solution{ Â
  // method to find factorial of given number   static int factorial( int n)   {     if (n == 0 )       return 1 ; Â
    return n*factorial(n - 1 );   } Â
  // Function to count   // all the possible combinations   // of K numbers having sum equals to N   static  int totalWays( int N, int K) { Â
    // If N<K     if (N < K)       return 0 ; Â
    // Storing numerator     int  n1 = factorial(N - 1 ); Â
    // Storing denominator     int n2 = factorial(K - 1 )*factorial(N - K);     int ans = (n1/n2); Â
    // Returning answer     return ans;   } Â
  // Driver method   public static void main(String[] args)   { Â
    int N = 7 ;     int K = 3 ;     int ans = totalWays(N, K);     System.out.println(ans);   } } Â
// This code is contributed by umadevi9616 |
Python3
# Python Program for the above approach Â
from math import factorial Â
Â
class Solution: Â
    # Function to count     # all the possible combinations     # of K numbers having sum equals to N     def totalWays( self , N, K): Â
        # If N<K         if (N < K):             return 0 Â
        # Storing numerator         n1 = factorial(N - 1 ) Â
        # Storing denominator         n2 = factorial(K - 1 ) * factorial(N - K) Â
        ans = (n1 / / n2) Â
        # Returning answer         return ans Â
Â
# Driver Code if __name__ = = '__main__' : Â Â Â Â N = 7 Â Â Â Â K = 3 Â Â Â Â ob = Solution() Â Â Â Â ans = ob.totalWays(N, K) Â Â Â Â print (ans) |
C#
// C# Program for the above approach using System; public class Solution { Â
  // method to find factorial of given number   static int factorial( int n) {     if (n == 0)       return 1; Â
    return n * factorial(n - 1);   } Â
  // Function to count   // all the possible combinations   // of K numbers having sum equals to N   static int totalWays( int N, int K) { Â
    // If N<K     if (N < K)       return 0; Â
    // Storing numerator     int n1 = factorial(N - 1); Â
    // Storing denominator     int n2 = factorial(K - 1) * factorial(N - K);     int ans = (n1 / n2); Â
    // Returning answer     return ans;   } Â
  // Driver method   public static void Main(String[] args) { Â
    int N = 7;     int K = 3;     int ans = totalWays(N, K);     Console.WriteLine(ans);   } } Â
// This code is contributed by umadevi9616 |
Javascript
<script> // Javascript program for the above approach Â
// Method to find factorial of given number function factorial(n) { Â Â Â Â if (n == 0) Â Â Â Â Â Â Â Â return 1; Â Â Â Â Â Â Â Â Â Â Â Â Â return n * factorial(n - 1); } Â
// Function to count all the possible // combinations of K numbers having // sum equals to N function totalWays( N, K) {          // If N<K     if (N < K)         return 0;          // Storing numerator     let n1 = factorial(N - 1);          // Storing denominator     let n2 = factorial(K - 1) * factorial(N - K);     let ans = (n1 / n2);          // Returning answer     return ans; } Â
// Driver code let N = 7; let K = 3; let ans = totalWays(N, K); Â
document.write(ans); Â
// This code is contributed by Shubham Singh </script> |
15
Time complexity: O(N)
Auxiliary Space: O(1)
Ready to dive in? Explore our Free Demo Content and join our DSA course, trusted by over 100,000 neveropen!