Arabic
Bulgarian
Chinese
Croatian
Czech
Danish
Dutch
English
Estonian
Finnish
French
German
Greek
Hebrew
Hindi
Hungarian
Icelandic
Indonesian
Italian
Japanese
Korean
Latvian
Lithuanian
Malagasy
Norwegian
Persian
Polish
Portuguese
Romanian
Russian
Serbian
Slovak
Slovenian
Spanish
Swedish
Thai
Turkish
Vietnamese

Arabic
Bulgarian
Chinese
Croatian
Czech
Danish
Dutch
English
Estonian
Finnish
French
German
Greek
Hebrew
Hindi
Hungarian
Icelandic
Indonesian
Italian
Japanese
Korean
Latvian
Lithuanian
Malagasy
Norwegian
Persian
Polish
Portuguese
Romanian
Russian
Serbian
Slovak
Slovenian
Spanish
Swedish
Thai
Turkish
Vietnamese

definition of Wikipedia

Advertizing ▼

This article needs additional citations for verification. Please help improve this article by adding citations to reliable sources. Unsourced material may be challenged and removed. (December 2008) |

In computer science, the **subset sum problem** is an important problem in complexity theory and cryptography. The problem is this: given a set of integers, is there a non-empty subset whose sum is zero? For example, given the set { −7, −3, −2, 5, 8}, the answer is *yes* because the subset { −3, −2, 5} sums to zero. The problem is NP-complete.

An equivalent problem is this: given a set of integers and an integer *s*, does any non-empty subset sum to *s*? Subset sum can also be thought of as a special case of the knapsack problem.^{[1]} One interesting special case of subset sum is the partition problem, in which *s* is half of the sum of all elements in the set.

## Contents |

The complexity (difficulty of solution) of subset sum can be viewed as depending on two parameters, *N*, the number of decision variables, and *P*, the precision of the problem (stated as the number of binary place values that it takes to state the problem). (Note: here the letters *N* and *P* mean something different than what they mean in the **NP** class of problems.)

The complexity of the best known algorithms is exponential in the smaller of the two parameters *N* and *P*. Thus, the problem is most difficult if *N* and *P* are of the same order. It only becomes easy if either *N* or *P* becomes very small.

If *N* (the number of variables) is small, then an exhaustive search for the solution is practical. If *P* (the number of place values) is a small fixed number, then there are dynamic programming algorithms that can solve it exactly.

Efficient algorithms for both small *N* and small *P* cases are given below.

There are several ways to solve subset sum in time exponential in *N*. The most naïve algorithm would be to cycle through all subsets of N numbers and, for every one of them, check if the subset sums to the right number. The running time is of order *O*(2^{N}*N*), since there are 2^{N} subsets and, to check each subset, we need to sum at most *N* elements.

A better exponential time algorithm is known which runs in time *O*(2^{N/2}). The algorithm splits arbitrarily the *N* elements into two sets of *N*/2 each. For each of these two sets, it stores a list of the sums of all 2^{N/2} possible subsets of its elements. Each of these two lists is then sorted. Using a standard comparison sorting algorithm for this step would take time *O*(2^{N/2}*N*). However, given a sorted list of sums for *k* elements, the list can be expanded to two sorted lists with the introduction of a (*k* + 1)st element, and these two sorted lists can be merged in time *O*(2^{k}). Thus, each list can be generated in sorted form in time *O*(2^{N/2}). Given the two sorted lists, the algorithm can check if an element of the first array and an element of the second array sum up to *s* in time *O*(2^{N/2}). To do that, the algorithm passes through the first array in decreasing order (starting at the largest element) and the second array in increasing order (starting at the smallest element). Whenever the sum of the current element in the first array and the current element in the second array is more than *s*, the algorithm moves to the next element in the first array. If it is less than *s*, the algorithm moves to the next element in the second array. If two elements with sum *s* are found, it stops. Horowitz and Sahni first published this algorithm in a technical report in 1972.^{[2]}

The problem can be solved as follows using dynamic programming. Suppose the sequence is

*x*_{1}, ...,*x*_{n}

and we wish to determine if there is a nonempty subset which sums to s. Let *N* be the sum of the negative values and *P* the sum of the positive values. Define the boolean-valued function *Q*(*i*,*s*) to be the value (**true** or **false**) of

- "there is a nonempty subset of
*x*_{1}, ...,*x*which sums to_{i}*s*".

Thus, the solution to the problem is the value of *Q*(*n*,0).

Clearly, *Q*(*i*,*s*) = **false** if *s* < *N* or *s* > *P* so these values do not need to be stored or computed. Create an array to hold the values *Q*(*i*,*s*) for 1 ≤ *i* ≤ *n* and *N* ≤ *s* ≤ *P*.

The array can now be filled in using a simple recursion. Initially, for *N* ≤ *s* ≤ *P*, set

*Q*(1,*s*) := (*x*_{1}==*s*).

Then, for *i* = 2, …, *n*, set

*Q*(*i*,*s*) :=*Q*(*i*− 1,*s*)**or**(*x*==_{i}*s*)**or***Q*(*i*− 1,*s*−*x*) for_{i}*N*≤*s*≤*P*.

For each assignment, the values of *Q* on the right side are already known, either because they were stored in the table for the previous value of *i* or because *Q*(*i* − 1,*s* − *x _{i}*) =

This algorithm is easily modified to return the subset with sum 0 if there is one.

This solution does not count as polynomial time in complexity theory because *P* − *N* is not polynomial in the *size* of the problem, which is the number of bits used to represent it. This algorithm is polynomial in the values of *N* and *P*, which are exponential in their numbers of bits.

For the case that each *x _{i}* is positive and bounded by the same constant, Pisinger found a linear time algorithm.

An approximate version of the subset sum would be: given a set of *N* numbers *x*_{1}, *x*_{2}, ..., *x _{N}* and a number

- yes, if there is a subset that sums up to
*s*; - no, if there is no subset summing up to a number between (1 −
*c*)*s*and*s*for some small*c*> 0; - any answer, if there is a subset summing up to a number between (1 −
*c*)*s*and*s*but no subset summing up to*s*.

If all numbers are non-negative, the approximate subset sum is solvable in time polynomial in *N* and 1/*c*.

The solution for subset sum also provides the solution for the original subset sum problem in the case where the numbers are small (again, for nonnegative numbers). If any sum of the numbers can be specified with at most *P* bits, then solving the problem approximately with *c* = 2^{−P} is equivalent to solving it exactly. Then, the polynomial time algorithm for approximate subset sum becomes an exact algorithm with running time polynomial in *N* and 2^{P} (i.e., exponential in *P*).

The algorithm for the approximate subset sum problem is as follows:

initialize a listSto contain one element 0. for eachifrom 1 toNdo letTbe a list consisting ofx+_{i}y, for allyinSletUbe the union ofTandSsortUmakeSempty letybe the smallest element ofUaddytoSfor each elementzofUin increasing order do //trim the list by eliminating numbers close to one another //and throw out elements greater thansify+cs/N<z≤s, sety=zand addztoSifScontains a number between (1 −c)sands, outputyes, otherwiseno

The algorithm is polynomial time because the lists *S*, *T* and *U* always remain of size polynomial in *N* and 1/*c* and, as long as they are of polynomial size, all operations on them can be done in polynomial time. The size of lists is kept polynomial by the trimming step, in which we only include a number *z* into *S* if it is greater than the previous one by *cs*/*N* and not greater than *s*.

This step ensures that each element in *S* is smaller than the next one by at least *cs*/*N* and do not contain elements greater than *s*. Any list with that property consists of no more than *N*/*c* elements.

The algorithm is correct because each step introduces an additive error of at most *cs*/*N* and *N* steps together introduce the error of at most *cs*.

- Cormen, Thomas H.; Leiserson, Charles E., Rivest, Ronald L., Stein, Clifford (2001) [1990]. "35.5: The subset-sum problem".
*Introduction to Algorithms*(2nd ed.). MIT Press and McGraw-Hill. ISBN 0-262-03293-7. - Michael R. Garey and David S. Johnson (1979).
*Computers and Intractability: A Guide to the Theory of NP-Completeness*. W.H. Freeman. ISBN 0-7167-1045-5. A3.2: SP13, pg.223.

**^**Martello, Silvano; Toth, Paolo (1990). "4 Subset-sum problem".*Knapsack problems: Algorithms and computer interpretations*. Wiley-Interscience. pp. 105–136. ISBN 0-471-92420-2. MR 1086874.**^**Horowitz, Ellis; Sahni, Sartaj (1974), "Computing partitions with applications to the knapsack problem",*Journal of the Association for Computing Machinery***21**: 277–292, DOI:10.1145/321812.321823, MR 0354006**^**Pisinger D (1999). "Linear Time Algorithms for Knapsack Problems with Bounded Weights".*Journal of Algorithms*, Volume 33, Number 1, October 1999, pp. 1–14

sensagent's content

- definitions
- synonyms
- antonyms
- encyclopedia

Dictionary and translator for handheld

New : sensagent is now available on your handheld

Advertising ▼

Webmaster Solution

Alexandria

A windows (pop-into) of information (full-content of Sensagent) triggered by double-clicking any word on your webpage. Give contextual explanation and translation from your sites !

SensagentBox

With a SensagentBox, visitors to your site can access reliable information on over 5 million pages provided by Sensagent.com. Choose the design that fits your site.

Business solution

Improve your site content

Add new content to your site from Sensagent by XML.

Crawl products or adds

Get XML access to reach the best products.

Index images and define metadata

Get XML access to fix the meaning of your metadata.

Please, email us to describe your idea.

Lettris

Lettris is a curious tetris-clone game where all the bricks have the same square shape but different content. Each square carries a letter. To make squares disappear and save space for other squares you have to assemble English words (left, right, up, down) from the falling squares.

boggle

Boggle gives you 3 minutes to find as many words (3 letters or more) as you can in a grid of 16 letters. You can also try the grid of 16 letters. Letters must be adjacent and longer words score better. See if you can get into the grid Hall of Fame !

English dictionary

Main references

Most English definitions are provided by WordNet .

English thesaurus is mainly derived from The Integral Dictionary (TID).

English Encyclopedia is licensed by Wikipedia (GNU).

Copyrights

The wordgames anagrams, crossword, Lettris and Boggle are provided by Memodata.

The web service Alexandria is granted from Memodata for the Ebay search.

The SensagentBox are offered by sensAgent.

Translation

Change the target language to find translations.

Tips: browse the semantic fields (see From ideas to words) in two languages to learn more.

last searches on the dictionary :

versity ·
vairamuthu ·
Parenchyma ·
Sestao ·
Flush (poker) ·
handball ·
Sinai ·
Magma (comics) ·
MEDOMAK ·
JANET PARSHALL ·

2664 online visitors

computed in 0.047s

I would like to report:

section :

a spelling or a grammatical mistake

an offensive content(racist, pornographic, injurious, etc.)

a copyright violation

an error

a missing statement

other

please precise: