| 
									
										
										
										
											2008-01-22 17:02:02 -05:00
										 |  |  |  | ! Copyright (c) 2008 Aaron Schaefer. | 
					
						
							| 
									
										
										
										
											2008-01-22 00:08:27 -05:00
										 |  |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							| 
									
										
										
										
											2008-10-30 22:04:44 -04:00
										 |  |  |  | USING: kernel math math.combinatorics math.functions math.parser math.ranges | 
					
						
							|  |  |  |  |     project-euler.common sequences sets ;
 | 
					
						
							| 
									
										
										
										
											2008-01-22 00:08:27 -05:00
										 |  |  |  | IN: project-euler.032 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | ! http://projecteuler.net/index.php?section=problems&id=32 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | ! DESCRIPTION | 
					
						
							|  |  |  |  | ! ----------- | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | ! The product 7254 is unusual, as the identity, 39 × 186 = 7254, containing | 
					
						
							|  |  |  |  | ! multiplicand, multiplier, and product is 1 through 9 pandigital. | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | ! Find the sum of all products whose multiplicand/multiplier/product identity | 
					
						
							|  |  |  |  | ! can be written as a 1 through 9 pandigital. | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | ! HINT: Some products can be obtained in more than one way so be sure to only | 
					
						
							|  |  |  |  | ! include it once in your sum. | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | ! SOLUTION | 
					
						
							|  |  |  |  | ! -------- | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | ! Generate all pandigital numbers and then check if they fit the identity | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | <PRIVATE
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | : source-032 ( -- seq )
 | 
					
						
							| 
									
										
										
										
											2009-04-17 17:17:11 -04:00
										 |  |  |  |     9 factorial iota [ | 
					
						
							| 
									
										
										
										
											2010-01-14 10:10:13 -05:00
										 |  |  |  |         9 iota permutation [ 1 + ] map 10 digits>integer | 
					
						
							| 
									
										
										
										
											2009-04-17 17:17:11 -04:00
										 |  |  |  |     ] map ;
 | 
					
						
							| 
									
										
										
										
											2008-01-22 00:08:27 -05:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | : 1and4 ( n -- ? )
 | 
					
						
							|  |  |  |  |     number>string 1 cut-slice 4 cut-slice
 | 
					
						
							| 
									
										
										
										
											2008-06-27 03:17:19 -04:00
										 |  |  |  |     [ string>number ] tri@ [ * ] dip = ;
 | 
					
						
							| 
									
										
										
										
											2008-01-22 00:08:27 -05:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | : 2and3 ( n -- ? )
 | 
					
						
							|  |  |  |  |     number>string 2 cut-slice 3 cut-slice
 | 
					
						
							| 
									
										
										
										
											2008-06-27 03:17:19 -04:00
										 |  |  |  |     [ string>number ] tri@ [ * ] dip = ;
 | 
					
						
							| 
									
										
										
										
											2008-01-22 00:08:27 -05:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | : valid? ( n -- ? )
 | 
					
						
							| 
									
										
										
										
											2008-10-30 22:04:44 -04:00
										 |  |  |  |     [ 1and4 ] [ 2and3 ] bi or ;
 | 
					
						
							| 
									
										
										
										
											2008-01-22 00:08:27 -05:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | : products ( seq -- m )
 | 
					
						
							| 
									
										
										
										
											2008-02-02 19:31:55 -05:00
										 |  |  |  |     [ 10 4 ^ mod ] map ;
 | 
					
						
							| 
									
										
										
										
											2008-01-22 00:08:27 -05:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | PRIVATE>
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | : euler032 ( -- answer )
 | 
					
						
							| 
									
										
										
										
											2010-02-27 14:52:24 -05:00
										 |  |  |  |     source-032 [ valid? ] filter products members sum ;
 | 
					
						
							| 
									
										
										
										
											2008-01-22 00:08:27 -05:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | ! [ euler032 ] 10 ave-time | 
					
						
							| 
									
										
										
										
											2008-11-05 01:11:15 -05:00
										 |  |  |  | ! 16361 ms ave run time - 417.8 SD (10 trials) | 
					
						
							| 
									
										
										
										
											2008-01-22 00:08:27 -05:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | ! ALTERNATE SOLUTIONS | 
					
						
							|  |  |  |  | ! ------------------- | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | ! Generate all reasonable multiplicand/multiplier pairs, then multiply and see | 
					
						
							|  |  |  |  | ! if the equation is pandigital | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | <PRIVATE
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | ! multiplicand/multiplier/product | 
					
						
							| 
									
										
										
										
											2010-02-25 02:54:41 -05:00
										 |  |  |  | : mmp ( x y -- n )
 | 
					
						
							|  |  |  |  |     2dup * [ number>string ] tri@ 3append string>number ;
 | 
					
						
							| 
									
										
										
										
											2008-01-22 00:08:27 -05:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | PRIVATE>
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | : euler032a ( -- answer )
 | 
					
						
							| 
									
										
										
										
											2010-02-25 02:54:41 -05:00
										 |  |  |  |     50 [1,b] 2000 [1,b] | 
					
						
							|  |  |  |  |     [ mmp ] cartesian-map concat
 | 
					
						
							|  |  |  |  |     [ pandigital? ] filter
 | 
					
						
							| 
									
										
										
										
											2010-02-27 14:52:24 -05:00
										 |  |  |  |     products members sum ;
 | 
					
						
							| 
									
										
										
										
											2008-01-22 00:08:27 -05:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-05 01:11:15 -05:00
										 |  |  |  | ! [ euler032a ] 10 ave-time | 
					
						
							|  |  |  |  | ! 2624 ms ave run time - 131.91 SD (10 trials) | 
					
						
							| 
									
										
										
										
											2008-01-22 00:08:27 -05:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-19 00:05:32 -04:00
										 |  |  |  | SOLUTION: euler032a |