-
Notifications
You must be signed in to change notification settings - Fork 1k
/
Copy pathPartitionProblem.cs
88 lines (85 loc) · 3.06 KB
/
PartitionProblem.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
/*
* The Problem is deciding whether a given multiset S of positive integers can be partitioned
into two subsets S1 and S2 such that the sum of the numbers in S1 equals the sum of the numbers in S2.
* Complexity O(N^2)
*/
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace NeoAlgo
{
class Program
{
public static bool NumberPartitiong(int[] numbers, int N)
{
int Sum = 0;
bool flag = false;
int[,] numbers2 = new int[N + 1, N + 1];
/*
* Calculate the sum of all elements in the array
* Saving every elemebt in first row and column in the new matrix
*/
for (int i = 1; i <= N; i++)
{
Sum += numbers[i - 1];
numbers2[i, 0] = numbers[i - 1];
numbers2[0, i] = numbers[i - 1];
}
int Sum2 = Sum / 2;
int Subset = 0;
for (int i = 1; i <= N; i++)
{
for (int j = i + 1; j <= N; j++)
{
/*
* Adding numbers to matrix that equals to sum / 2 or if (sum / 2) + 1 in case sum is odd
*/
if (Sum % 2 != 0 && (numbers2[i, j - 1] + numbers2[0, j] > Sum2 || numbers2[i, j - 1] + numbers2[0, j] > Sum2 + 1) || j == 1)
numbers2[i, j] = numbers2[i, 0] + numbers2[0, j];
else if (Sum % 2 == 0 && numbers2[i, j - 1] + numbers2[0, j] > Sum2 || j == 1)
numbers2[i, j] = numbers2[i, 0] + numbers2[0, j];
else
numbers2[i, j] = numbers2[i, j - 1] + numbers2[0, j];
/*
* if Element in matrix = sum / 2 so Add 1 to subset
* if subset = 2 so we have reached our Goal
*/
if (Sum % 2 != 0 && (numbers2[i, j] == Sum2 + 1 || numbers2[i, j] == Sum2))
{
Subset++;
}
else if (Sum % 2 == 0 && numbers2[i, j] == Sum2)
{
Subset++;
}
}
if (Subset == 2)
{
flag = true;
break;
}
}
return flag;
}
static void Main(string[] args)
{
Console.WriteLine("Enter No. of Vertices: ");
int N = int.Parse(Console.ReadLine());
int[] numbers = new int[N];
for (int i = 0; i < N; i++)
{
numbers[i] = int.Parse(Console.ReadLine());
}
Console.WriteLine(NumberPartitiong(numbers, N)); ;
/*
* Input: N = 5
* numbers: 5 6 4 2 3 1
* Sum = 21
* S1: [5, 2, 3] S2: [6, 4, 1]
* OutPut = True
*/
}
}
}