Еще один способ сделать это:
(define (random-vector count seed)
(let loop ((vec '(vector)) (i count))
(cond ((> i 0)
(loop (cons (random seed) vec) (sub1 i)))
(else (eval (reverse vec))))))
Может быть не лучшим решением, но показывает, как написать и оценить программу Scheme во время выполнения. Может быть полезно для новых интриганов.
Некоторые примеры использования:
> (random-vector 10 100)
#10(53 57 47 34 88 32 70 66 92 56)
> (random-vector 100 500)
#100(42 1 250 396 63 120 185 397 251 88 497 271 246 327 91 108 240 306 445 180 292 55 497 67 445 300 279 229 342 122 498 10 253 248 44 133 450 55 112 13 309 255 101 456 272 7 239 113 394 453 89 343 386 471 92 44 61 239 382 313 78 22 376 466 24 97 286 343 237 220 458 153 131 217 390 94 53 461 237 22 327 196 460 436 311 418 41 124 79 24 37 388 344 176 314 432 26 341 303 218)