fork download
  1. (declaim (optimize (speed 3) (safety 0) (debug 0))
  2. (inline distance))
  3.  
  4. (defun distance (pos1 pos2)
  5. (+ (expt (- (the unsigned-byte (car pos1)) (the unsigned-byte (car pos2))) 2)
  6. (expt (- (the unsigned-byte (cdr pos1)) (the unsigned-byte (cdr pos2))) 2)))
  7.  
  8. (defun print-as-board (size poss)
  9. (loop
  10. for x below size
  11. do (loop
  12. for y below size
  13. do (format t "~a"
  14. (if (find (cons x y) poss :test #'equalp)
  15. "o"
  16. "+")))
  17. (format t "~%")))
  18.  
  19. ;; 遅いバージョン
  20. (defun solve (size num)
  21. (labels
  22. ((rec (i poss distances)
  23. (when (zerop i)
  24. (print-as-board size poss)
  25. (return-from solve))
  26. (loop
  27. for x below size
  28. do (loop
  29. for y below size
  30. for pos = (cons x y)
  31. for ds = (mapcar (lambda (pos1) (distance pos pos1)) poss)
  32. when (= (length poss)
  33. (length (remove-duplicates ds)))
  34. unless (find pos poss :test #'equalp)
  35. unless (intersection distances ds)
  36. do (rec (1- i) (cons pos poss) (append ds distances))))))
  37. (rec num () ())))
  38.  
  39. (defun solve2 (size num)
  40. (declare (unsigned-byte size num))
  41. (let ((pos-array (make-array num :fill-pointer 0))
  42. (dist-array (make-array (the unsigned-byte (/ (* num (1- num)) 2))
  43. :element-type 'unsigned-byte
  44. :initial-element 0)))
  45. (labels
  46. ((rec (i j di)
  47. (when (zerop i)
  48. (print-as-board size pos-array) (terpri)
  49. (return-from solve2))
  50. (loop
  51. for j fixnum from j below (* size size)
  52. for pos = (cons (floor j size) (mod j size))
  53. unless (find pos pos-array :test #'equalp)
  54. unless (loop
  55. for p across pos-array
  56. for i from di
  57. for d = (the unsigned-byte (distance pos p))
  58. when (find d dist-array :end i)
  59. return t
  60. do (setf (aref dist-array i) d))
  61. do (vector-push pos pos-array)
  62. (rec (the unsigned-byte (1- i)) j (+ di (length pos-array) -1))
  63. (vector-pop pos-array))))
  64. (rec num 0 0))))
  65.  
  66. (solve2 5 5)
  67. (solve2 6 6)
  68. (solve2 7 7)
Success #stdin #stdout 1.27s 10784KB
stdin
Standard input is empty
stdout
oo++o
+++++
+o+++
+++++
+++o+

oo++++
+++o++
++++++
+++++o
++++++
++o++o

o+o++++
++o++++
++++++o
o++++++
+++++++
+++++o+
++++++o