[bugfix] circular-list? in srfi-1
circular-list? does not get stuck in an infinite loop if it is given a list such as '(1 2 3 2 3 2 3 2 3 ...).
This commit is contained in:
parent
21b17cfd59
commit
dfb525157e
|
@ -51,19 +51,16 @@
|
||||||
;; list=
|
;; list=
|
||||||
(define (not-pair? x)
|
(define (not-pair? x)
|
||||||
(not (pair? x)))
|
(not (pair? x)))
|
||||||
|
;; detects circular list using Floyd's cycle-finding algorithm
|
||||||
(define (circular-list? x)
|
(define (circular-list? x)
|
||||||
(and (pair? x)
|
(let rec ((rapid x) (local x))
|
||||||
(let rec ((lst (cdr x)))
|
(if (and (pair? rapid) (pair? (cdr rapid)))
|
||||||
(cond ((not-pair? lst) #f)
|
(if (eq? (cddr rapid) (cdr local))
|
||||||
((null? lst) #f)
|
#t
|
||||||
((eq? x lst) #t)
|
(rec (cddr rapid) (cdr local)))
|
||||||
(else (rec (cdr lst)))))))
|
#f)))
|
||||||
|
|
||||||
;; if list? is support circular list, (define proper-list? list?)
|
(define proper-list? list?)
|
||||||
(define (proper-list? x)
|
|
||||||
(if (not (circular-list? x))
|
|
||||||
(list? x)))
|
|
||||||
|
|
||||||
(define (dotted-list? x)
|
(define (dotted-list? x)
|
||||||
(and (pair? x)
|
(and (pair? x)
|
||||||
|
|
Loading…
Reference in New Issue