| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | ! Based on http://www.ffconsultancy.com/ocaml/sudoku/index.html | 
					
						
							| 
									
										
										
										
											2014-07-22 09:09:26 -04:00
										 |  |  | USING: columns combinators combinators.short-circuit generalizations io | 
					
						
							| 
									
										
										
										
											2014-06-10 18:46:54 -04:00
										 |  |  | io.styles kernel math math.parser namespaces sequences ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | IN: sudoku | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | SYMBOL: solutions | 
					
						
							|  |  |  | SYMBOL: board | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-17 23:29:32 -05:00
										 |  |  | : pair+ ( a b c d -- a+b c+d ) swapd [ + ] 2bi@ ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-09 03:14:14 -04:00
										 |  |  | : row ( n -- row ) board get nth ;
 | 
					
						
							|  |  |  | : board> ( m n -- x ) row nth ;
 | 
					
						
							|  |  |  | : >board ( row m n -- ) row set-nth ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-29 23:19:07 -05:00
										 |  |  | : row-any? ( n y -- ? ) row member? ;
 | 
					
						
							|  |  |  | : col-any? ( n x -- ? ) board get swap <column> member? ;
 | 
					
						
							|  |  |  | : cell-any? ( n x y i -- ? ) 3 /mod pair+ board> = ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-29 23:19:07 -05:00
										 |  |  | : box-any? ( n x y -- ? )
 | 
					
						
							| 
									
										
										
										
											2017-06-01 17:59:35 -04:00
										 |  |  |     [ 3 /i 3 * ] bi@ 9 <iota> [ cell-any? ] 3 nwith any? ;
 | 
					
						
							| 
									
										
										
										
											2014-06-10 18:46:54 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : board-any? ( n x y -- ? )
 | 
					
						
							|  |  |  |     { [ nip row-any? ] [ drop col-any? ] [ box-any? ] } 3|| ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | DEFER: search | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : assume ( n x y -- )
 | 
					
						
							| 
									
										
										
										
											2014-06-10 18:46:54 -04:00
										 |  |  |     [ >board ] [ [ 1 + ] dip search f ] [ >board ] 2tri ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : attempt ( n x y -- )
 | 
					
						
							| 
									
										
										
										
											2014-06-10 18:46:54 -04:00
										 |  |  |     3dup board-any? [ 3drop ] [ assume ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : solve ( x y -- )
 | 
					
						
							|  |  |  |     9 [ 1 + 2over attempt ] each-integer 2drop ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : cell. ( cell -- )
 | 
					
						
							|  |  |  |     [ [ number>string write ] [ "." write ] if* ] with-cell ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-10 18:46:54 -04:00
										 |  |  | : row. ( row -- )
 | 
					
						
							|  |  |  |     [ [ cell. ] each ] with-row ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : board. ( board -- )
 | 
					
						
							| 
									
										
										
										
											2014-06-10 18:46:54 -04:00
										 |  |  |     standard-table-style [ [ row. ] each ] tabular-output nl ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : solution. ( -- )
 | 
					
						
							|  |  |  |     solutions inc "Solution:" print board get board. ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : search ( x y -- )
 | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2009-08-13 20:21:44 -04:00
										 |  |  |         { [ over 9 = ] [ [ drop 0 ] dip 1 + search ] } | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |         { [ over 0 = over 9 = and ] [ 2drop solution. ] } | 
					
						
							| 
									
										
										
										
											2009-08-13 20:21:44 -04:00
										 |  |  |         { [ 2dup board> ] [ [ 1 + ] dip search ] } | 
					
						
							| 
									
										
										
										
											2008-04-11 13:57:43 -04:00
										 |  |  |         [ solve ] | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     } cond ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : sudoku ( board -- )
 | 
					
						
							|  |  |  |     [ | 
					
						
							|  |  |  |         "Puzzle:" print dup board. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         0 solutions set
 | 
					
						
							|  |  |  |         [ clone ] map board set
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         0 0 search | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         solutions get number>string write " solutions." print
 | 
					
						
							|  |  |  |     ] with-scope ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : sudoku-demo ( -- )
 | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         { f f 1 f f 5 3 f f } | 
					
						
							|  |  |  |         { f 5 f 4 9 f f f f } | 
					
						
							|  |  |  |         { f f f 1 f 2 f 6 4 } | 
					
						
							|  |  |  |         { f f f f f f 7 5 f } | 
					
						
							|  |  |  |         { 6 f f f f f f f 1 } | 
					
						
							|  |  |  |         { f 3 5 f f f f f f } | 
					
						
							|  |  |  |         { 4 6 f 9 f 3 f f f } | 
					
						
							|  |  |  |         { f f f f 2 4 f 9 f } | 
					
						
							|  |  |  |         { f f 3 6 f f 1 f f } | 
					
						
							|  |  |  |     } sudoku ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | MAIN: sudoku-demo |