You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					28 lines
				
				606 B
			
		
		
			
		
	
	
					28 lines
				
				606 B
			| 
											3 years ago
										 | /** | ||
|  |  * Obliterator Power Set Function | ||
|  |  * =============================== | ||
|  |  * | ||
|  |  * Iterator returning the power set of the given array. | ||
|  |  */ | ||
|  | var Iterator = require('./iterator.js'), | ||
|  |   combinations = require('./combinations.js'), | ||
|  |   chain = require('./chain.js'); | ||
|  | 
 | ||
|  | /** | ||
|  |  * Power set. | ||
|  |  * | ||
|  |  * @param  {array}    array - Target array. | ||
|  |  * @return {Iterator} | ||
|  |  */ | ||
|  | module.exports = function powerSet(array) { | ||
|  |   var n = array.length; | ||
|  | 
 | ||
|  |   var iterators = new Array(n + 1); | ||
|  | 
 | ||
|  |   iterators[0] = Iterator.of([]); | ||
|  | 
 | ||
|  |   for (var i = 1; i < n + 1; i++) iterators[i] = combinations(array, i); | ||
|  | 
 | ||
|  |   return chain.apply(null, iterators); | ||
|  | }; |