Related Articles

# Find the sum of maximum difference possible from all subset of a given array.

• Difficulty Level : Hard
• Last Updated : 28 Apr, 2021

We are given an array arr[] of n non-negative integers (repeated elements allowed), find out the sum of maximum difference possible from all subsets of the given array.
Suppose max(s) represents the maximum value in any subset ‘s’ whereas min(s) represents the minimum value in the set ‘s’. We need to find the sum of max(s)-min(s) for all possible subsets.

Examples:

```Input : arr[] = {1, 2, 3}
Output : result = 6

Explanation :
All possible subset and for each subset s,
max(s)-min(s) are as :
SUBSET    |  max(s) | min(s) | max(s)-min(s)
{1, 2}    |  2      |  1     |   1
{1, 3}    |  3      |  1     |   2
{2, 3}    |  3      |  2     |   1
{1, 2, 3} |  3      |  1     |   2
Total Difference sum = 6
Note : max(s) - min(s) for all subset with
single element must be zero.

Input : arr[] = {1, 2, 2}
Output : result = 3

Explanation :
All possible subset and for each subset s,
max(s)-min(s) are as :
SUBSET  |  max(s) | min(s)| max(s)-min(s)
{1, 2}  |  2      |  1    |   1
{1, 2}  |  2      |  1    |   1
{2, 2}  |  2      |  2    |   0
{1, 2, 2} |  2      |  1    |   1
Total Difference sum = 3```

Basic Approach: Compute the sum of the maximum element of each subset, and the sum of the minimum element of each subset separately, and then subtract the minimum sum from the maximum to get the answer. The sum of the maximum/ minimum element of each subset can be computed easily by iterating through the elements of each subset. But as we have to iterate through all subsets the time complexity for this approach is exponential O(n2^n).
Efficient Approach:
As we have to compute the sum of the maximum element of each subset, and the sum of the minimum element of each subset separately here is an efficient way to perform this calculation.
Sum of Minimum Elements of All Subsets:
Let us say that the elements of arr[] in non-decreasing order are {a1,a2,…, an}. Now, we can partition the subsets of arr[] into the following categories:

• Subsets containing element a1: These subsets can be obtained by taking any subset of {a2,a3,…, an} and then adding a1 into it. The number of such subsets will be 2n-1, and they all have a1 as their minimum element.
• Subsets not containing element a1, but containing a2: These subsets can be obtained by taking any subset of {a3, a4,…,an}, and then adding a2 into it. The number of such subsets will be 2n-2, and they all have a2 as their minimum element.
• …..
• Subsets not containing elements a1, a2,…, ai-1 but containing ai: These subsets can be obtained by taking any subset of {ai+1,ai+2,…, an}, and then adding ai into it. The number of such subsets will be 2n-i, and they all have ai as their minimum element.

t can be seen that the above iteration is complete, i.e., it considers each subset exactly once. Hence, the sum of the minimum element of all subsets will be:
min_sum = a1*2n-1 + a2*2n-2 + … + an*20
This sum can be computed easily in linear time with help of the Horner method
Similarly, we can compute the sum of the maximum element of all subsets of arr[]. The only difference is that we need to iterate the elements of arr[] in non-increasing order.
Note: We may have a large answer, so we have to calculate the answer with mod 10^9 +7.

## C++

 `// CPP for finding max min difference``// from all subset of given set``#include ``using` `namespace` `std;` `const` `long` `long` `int` `MOD = 1000000007;` `// function for sum of max min difference``int` `maxMin (``int` `arr[], ``int` `n)``{``    ``// sort all numbers``    ``sort(arr, arr + n);``    ` `    ``// iterate over array and with help of``    ``// horner's rule calc max_sum and min_sum``    ``long` `long` `int` `min_sum = 0, max_sum = 0;``    ``for` `(``int` `i = 0; i < n; i++)``    ``{``        ``max_sum = 2 * max_sum + arr[n-1-i];``        ``max_sum %= MOD;``        ``min_sum = 2 * min_sum + arr[i];``        ``min_sum %= MOD;``    ``}` `    ``return` `(max_sum - min_sum + MOD) % MOD;``}` `// Driver Code``int` `main()``{``    ``int` `arr[] = {1, 2, 3, 4};``    ``int` `n = ``sizeof``(arr) / ``sizeof``(arr);``    ``cout << maxMin(arr,n);``    ``return` `0;``}`

## Java

 `// JAVA Code for Find the sum of maximum``// difference possible from all subset``// of a given array.``import` `java.util.*;` `class` `GFG {``    ` `    ``public` `static` `int` `MOD = ``1000000007``;``    ` `    ``// function for sum of max min difference``    ``public` `static` `long` `maxMin (``int` `arr[], ``int` `n)``    ``{``        ``// sort all numbers``        ``Arrays.sort(arr);``        ` `        ``// iterate over array and with help of``        ``// horner's rule calc max_sum and min_sum``        ``long` `min_sum = ``0``, max_sum = ``0``;``        ``for` `(``int` `i = ``0``; i < n; i++)``        ``{``            ``max_sum = ``2` `* max_sum + arr[n - ``1` `- i];``            ``max_sum %= MOD;``            ``min_sum = ``2` `* min_sum + arr[i];``            ``min_sum %= MOD;``        ``}``    ` `        ``return` `(max_sum - min_sum + MOD)%MOD;``    ``}``    ` `    ``// Driver Code``    ``public` `static` `void` `main(String[] args)``    ``{``            ``int` `arr[] = {``1``, ``2``, ``3``, ``4``};``            ``int` `n = arr.length;``            ``System.out.println(maxMin(arr, n));``    ``}``}` `// This code is contributed by Arnav Kr. Mandal.`

## Python3

 `# python for finding max min difference``#from all subset of given set` `MOD ``=` `1000000007``;` `# function for sum of max min difference``def` `maxMin (arr,n):``    ` `    ``# sort all numbers``    ``arr.sort()``    ` `    ``# iterate over array and with help of``    ``# horner's rule calc max_sum and min_sum``    ``min_sum ``=` `0``    ``max_sum ``=` `0``    ``for` `i ``in` `range``(``0``,n):``        ` `        ``max_sum ``=` `2` `*` `max_sum ``+` `arr[n``-``1``-``i];``        ``max_sum ``%``=` `MOD;``        ``min_sum ``=` `2` `*` `min_sum ``+` `arr[i];``        ``min_sum ``%``=` `MOD;``    ` `    ``return` `(max_sum ``-` `min_sum ``+` `MOD) ``%` `MOD;` `# Driver Code``arr ``=` `[``1``, ``2``, ``3``, ``4``]``n ``=` `len``(arr)``print``( maxMin(arr, n))` `# This code is contributed by Sam007.`

## C#

 `// C# Code to Find the sum of maximum``// difference possible from all subset``// of a given array.``using` `System;` `class` `GFG {``    ` `    ``public` `static` `int` `MOD = 1000000007;``    ` `    ``// function for sum of max min difference``    ``public` `static` `long` `maxMin (``int` `[]arr, ``int` `n)``    ``{``        ``// sort all numbers``        ``Array.Sort(arr);``        ` `        ``// iterate over array and with help of``        ``// horner's rule calc max_sum and min_sum``        ``long` `min_sum = 0, max_sum = 0;``        ``for` `(``int` `i = 0; i < n; i++)``        ``{``            ``max_sum = 2 * max_sum + arr[n - 1 - i];``            ``max_sum %= MOD;``            ``min_sum = 2 * min_sum + arr[i];``            ``min_sum %= MOD;``        ``}``    ` `        ``return` `(max_sum - min_sum + MOD) % MOD;``    ``}``    ` `    ``// Driver Code``    ``public` `static` `void` `Main()``    ``{``            ``int` `[]arr = {1, 2, 3, 4};``            ``int` `n = arr.Length;``            ``Console.Write(maxMin(arr, n));   ``    ``}``}` `// This code is contributed by nitin mittal`

## PHP

 ``

## Javascript

 ``

Output:

`23`