Update class name

This commit is contained in:
Stepfen Shawn
2020-08-02 15:21:33 +08:00
committed by GitHub
parent 98428462cd
commit 90f59aa6ac

View File

@ -1,3 +1,4 @@
package DynamicProgramming;
// Partition a set into two subsets such that the difference of subset sums is minimum // Partition a set into two subsets such that the difference of subset sums is minimum
/* /*
@ -17,56 +18,56 @@ Subset2 = {36, 40} ; sum of Subset2 = 76
import java.util.*; import java.util.*;
import java.lang.*; import java.lang.*;
import java.io.*; import java.io.*;
class GFG public class MinimumSumPartition
{ {
public static void main (String[] args) public static void main (String[] args)
{ {
Scanner sc=new Scanner(System.in); Scanner sc = new Scanner(System.in);
int t=sc.nextInt(); int t = sc.nextInt();
while(t-->0) while(t-->0)
{ {
int n=sc.nextInt(); int n = sc.nextInt();
int arr[]=new int[n]; int arr[] = new int[n];
int sum=0; int sum = 0;
for(int i=0;i<n;i++) for(int i = 0;i < n;i++)
{ {
arr[i]=sc.nextInt(); arr[i] = sc.nextInt();
sum+=arr[i]; sum += arr[i];
} }
int ans[]=new int[sum]; int ans[] = new int[sum];
ans=subset(arr,sum); ans = subset(arr,sum);
int min=Integer.MAX_VALUE; int min = Integer.MAX_VALUE;
for(int i=0;i<ans.length;i++) for (int i = 0; i < ans.length; i++)
min=Math.min(min,(sum-2*ans[i])); min = Math.min(min,(sum-2*ans[i]));
System.out.println(min); System.out.println(min);
} }
} }
static int[] subset(int arr[],int sum) static int[] subset(int arr[],int sum)
{ {
int n=arr.length; int n = arr.length;
boolean dp[][]=new boolean[n+1][sum+1]; boolean dp[][] = new boolean[n+1][sum+1];
for(int i=0;i<=n;i++) for(int i = 0; i <= n; i++)
dp[i][0]=true; dp[i][0] = true;
for(int i=1;i<=sum;i++) for(int i = 1; i <= sum; i++)
dp[0][i]=false; dp[0][i] = false;
// subset sum concept // subset sum concept
for(int i=1;i<=n;i++) for(int i = 1; i <= n; i++)
{ {
for(int j=1;j<=sum;j++) for(int j = 1; j <= sum; j++)
{ {
if(arr[i-1]<=j) if(arr[i-1] <= j)
dp[i][j]=dp[i-1][j-arr[i-1]] || dp[i-1][j]; dp[i][j] = dp[i-1][j-arr[i-1]] || dp[i-1][j];
else else
dp[i][j]=dp[i-1][j]; dp[i][j] = dp[i-1][j];
} }
} }
//storing last dp column whose value is true till sum/2 //storing last dp column whose value is true till sum/2
int index[]=new int[sum]; int index[] = new int[sum];
int p=0; int p = 0;
for(int i=0;i<=sum/2;i++) for(int i = 0 ; i <= sum / 2; i++)
{ {
if(dp[n][i]==true) if(dp[n][i] == true)
index[p++]=i; index[p++] = i;
} }
return index; return index;
} }