Download paper

In number hypothesis and software engineering the partition problem

Categories: Software Engineering

In number hypothesis and software engineering, the partition problem, or number partitioning,[1] is the obligation of choosing whether a given multi set S of positive whole numbers can be parceled into two subsets S1 and S2 with the end goal that the entirety of the numbers in S1 squares with the total of the numbers in S2. Despite the fact that the segment issue is NP-finished, there is a pseudo-polynomial time dynamic programming arrangement, and there are heuristics that take care of the issue in numerous example, either ideally or generally.

Thus, it has been classified “the most effortless NP-difficult issue”.

There is an enhancement variant of the segment issue, which is to parcel the multiset S into two subsets S1, S2 with the end goal that the distinction between the entirety of components in S1 and the total of components in S2 is decreased. The advancement form is NP-hard, yet can be comprehended effectively practically speaking.


Given S = {6,1,1,4,4,1}, a legitimate answer for the segment issue is the two sets S1 = {1,1,1,4} and S2 = {1,6}.

The two sets total to 7, and they parcel S. Note that this arrangement isn’t one of a kind. S1 = {6,1,1} and S2 = {4,4,1} is another arrangement.

Few out of every odd multi set of positive whole numbers has a parcel into two parts with equivalent entirety. A case of such a set is S = {2,5}.

Pseudo-polynomial time algorithm

The issue can be comprehended utilizing dynamic programming when the extent of the set and the measure of the entirety of the numbers in the set are not very enormous to give the capacity prerequisites infeasible.

Top Experts
Chris Al
Verified expert
4.9 (478)
Professor Harris
Verified expert
4.9 (457)
Verified expert
4.9 (247)
hire verified expert

Assume the contribution to the calculation is a multi set S of cardinality N :

S = {x1, …, x N}

Give K a chance to be the entirety of all components in S. That is: K = x1 + … + xN. We will fabricate a calculation that decides if there is a subset of S that totals to [K/2]. On the off chance that there is a subset, at that point:

If K is even, the remainder of S likewise wholes to [K/2]

If K is odd, at that point the remainder of S entireties to [K/2]. This is as great an answer as would be prudent.

Recurrence relation

We wish to decide whether there is a subset of S that wholes to [K/2]. Let:

p(i, j) be True if a subset of { x1, …, xj } totals to I and False generally.

At that point p([K/2], N) is True if and just if there is a subset of S that aggregates to [K/2]. The objective of our calculation will be to figure p([K/2], N). In help of this, we have the accompanying repeat connection.

p(i, j) is True if either p(i, j ? 1) is True or if p(i ? xj, j ? 1) is True

p(i, j) is False something else

The thinking for this is as per the following: there is some subset of S that aggregates to I utilizing numbers

x1, …, xj

on the off chance that and just if both of coming up next is valid:

There is a subset of { x1, …, xj?1 } that entireties to I;

there is a subset of { x1, …, xj?1 } that entireties to I ? xj, since xj + that subset’s aggregate = I.

The pseudo-polynomial algorithm

The calculation comprises of structure up a table of size [K/2] by N containing the estimations of the repeat. Keep in mind that K is the total of all N components in S. When the entire table is filled in, we return P([K/2] , N ) . The following is an image of the table P. There is a blue bolt starting with one square then onto the next if the estimation of the objective square may rely upon the estimation of the source-square. This reliance is a property of the repeat connection.

if and only if both of coming up next is valid:

There is a subset of { x1, …, xj?1 } that entireties to I;

there is a subset of { x1, …, xj?1 } that entireties to I ? xj, since xj + that subset’s aggregate = I.

INPUT: A list of integers S

OUTPUT: True if S can be partitioned into two subsets that have equal sum

  1. function find_partition(S):
  2. n ? |S|
  3. K ? sum(S)
  4. P ? empty boolean table of size [K/2]+ 1) by (n + 1)
  5. initialize top row (P(0,x)) of P to True
  6. initialize leftmost column (P(x, 0)) of P, except for P(0, 0) to False
  7. for i from 1 to [K/2]
  8. for j from 1 to n
  9. if ( i – S[j]) >= 0
  10. P(i, j) ? P(i, j-1) or P(i-S[j], j-1)
  11. else
  12. P(i, j) ? P(i, j-1)
  13. return P([K/2], n)


The following is the table P for the precedent set utilized above S = {6, 1, 1, 4, 4, 1}:

THhe section in line c and column{ s1,s2· · ,sk} show climate there is a subset

of {S1,s2,· ..,sk} that bsums to c.

T=True F=False

{} {6} {6,1} {6,1,1} {6,1,1,4} {6,1,1,4,4} {6,1,1,4,4,1}








This algorithm keeps running in time O(K N), where N is the quantity of components in the info set and K is the whole of components in the information set.

The algorithm can be extended to the k-way multi-partitioning problem, but then takes O(n(k ? 1)mk ? 1) memory where m is the largest number in the input, making it unsuitable even for k = 3 unless the inputs are very small numbers.[3]

Special case of the subset-sum problem

The parcel issue can be seen as an exceptional instance of the subset total issue and the pseudo-polynomial time dynamic programming arrangement given above sums up to an answer for the subset whole issue.

Approximation algorithm approaches

A few heuristic calculations exist to deliver approximations to the segment advancement issue. These can be reached out to direct space accurate calculations.

The greedy algorithm

One way to deal with the issue, imitating the manner in which kids pick groups for a diversion, is the insatiable calculation, which rehashes through the numbers in slipping request, distributing every one of them to whichever subset has the littler whole. This methodology has a running time of O(n log n). This heuristic functions admirably practically speaking when the numbers in the set are of about a similar size as its cardinality or less, however it isn’t ensured to deliver the most ideal parcel. For instance, given the set S = {5, 6, 7, 8, 9} as info, this eager calculation would parcel S into subsets {5, 6, 9} and {7, 8}; in any case, S has a precisely adjusted segment into subsets {8, 9} and {5, 6, 7}.

This eager methodology is known to give a 7?6-estimate to the ideal arrangement of the streamlining variant; that is, in the event that the insatiable calculation yields two sets An and B, at that point max(?A, ?B) ? 7/6 OPT, where OPT is the span of the bigger set in the most ideal segment. The following is a precedent (written in Python) for the eager calculation.


“returns: An attempt at a partition of `int_list` into two sets of equal sum”

A = set()

B = set()

for n in sorted(int_list, reverse=True):

if sum(A) < sum(B):




return (A, B)

This algorithm can be stretched out to the instance of k > 2 sets: to take the k biggest components, and for each segment of them, expands the parcel by adding the rest of the components progressively to whichever set is littler. (The simple version above corresponds to k = 2.) This version runs in time O(2k n2) and is known to give a 4/3-1/3k approximation.[4] ?hus, we have a polynomial-time guess plot (PTAS) for the number segment issue, however this is certainly not a completely polynomial time estimate conspire (the running time is exponential in the ideal guess ensure). In any case, there are contrast of this thought are completely polynomial-time estimation plans for the subset-aggregate issue, and subsequently for the segment issue also.

Differencing algorithm

Another heuristic is the largest differencing method (LDM),[7] also called the Karmarkar-Karp heuristic[3] after the pair of scientists that published it in 1982.[8] LDM operates in two phases. The primary phase of the calculation takes the two biggest numbers from the info and replaces them by their distinction; this is rehashed until just a single number remains. The substitution speaks to the choice to put the two numbers in various sets, without quickly choosing which one is in which set. Toward the finish of stage one, the single staying number is the distinction of the two subset aggregates. The second phase reconstructs the actual solution.[2]

The differencing heuristic performs better than the greedy one, but is still bad for instances where the numbers are exponential in the size of the set.[2]

The accompanying Java code actualizes the primary period of Karmarkar- Karp. It utilizes a stack to proficiently discover the pair of biggest outstanding numbers.

intkarmarkarKarpPartition(int[] baseArr) {

// create max heap

Priority Queue heap = new Priority Queue(base Arr.length, REVERSE_INT_CMP);

for (int value : baseArr) {



while(heap.size() > 1) {

int val1 = heap.poll();

int val2 = heap.poll();

heap.add(val1 – val2);




Other approaches

There are also anytime algorithms, based on the differencing heuristic, that first find the solution returned by the differencing heuristic, then find progressively better solutions as time allows (possibly requiring exponential time to reach optimality, for the worst examples).[9]

Hard instances

Sets with just one, or no segments will in general be firm (or most costly) to settle contrasted with their info sizes. At the point when the qualities are little contrasted with the span of the set, immaculate segments are almost certain. The issue is known to encounter a “stage progress”; being likely for certain sets and impossible for other people. On the off chance that m is the quantity of bits expected to express any number in the set and n is the extent of the set then {displaystyle m/n1 will in general have few or no arrangements. As n and m get bigger, the likelihood of an ideal segment goes to 1 or 0 separately. This was originally argued based on empirical evidence by Gent and Walsh,[10] then using methods from statistical physics by Mertens,[11] and later proved by Borgs, Chayes, and Pittel.[12]

Variants and generalizations

The restriction of requiring the partition to have equal size is also NP-hard.

There is a problem called the 3-partition problem which is to partition the set S into |S|/3 triples each with the same sum. This problem is quite different than the partition problem and has no pseudo-polynomial time algorithm unless P = NP.[13]

The multi-way partition problem generalizes the optimization version of the partition problem. Here, the goal is to divide a set or multiset of n integers into a given number k of subsets, minimizing the difference between the smallest and the largest subset sums.[3]

Probabilistic version

A related issue, to some degree like the Birthday conundrum, is that of deciding the extent of the information set so we have a likelihood of one a large portion of that there is an answer, under the presumption that every component in the set is arbitrarily chosen with uniform circulation among 1 and some given esteem.

The answer for this issue can be outlandish, similar to the birthday logical inconsistency.

Cite this page

In number hypothesis and software engineering the partition problem. (2019, Nov 20). Retrieved from

Are You on a Short Deadline? Let a Professional Expert Help You