Code Review

Compare your solutions

    #| BEGIN (Введите свое решение) |#
(define (union-set s1 s2)
  (list->tree (union-set-list
                              (tree->list-2 s1)
                              (tree->list-2 s2))))

(define (intersection-set s1 s2)
  (list->tree (intersection-set-list 
                                     (tree->list-2 s1)
                                     (tree->list-2 s2))))

(define (intersection-set-list set1 set2)
  (cond ((or (null? set1) (null? set2)) '())
        ((element-of-set-list? (car set1) set2)
         (cons (car set1)
               (intersection-set-list (cdr set1) set2)))
        (else (intersection-set-list (cdr set1) set2))))

(define (element-of-set-list? x set)
  (cond ((null? set) #f)
        ((equal? x (car set)) #t)
        (else (element-of-set-list? x (cdr set)))))

(define (adjoin-set x set)
  (cond ((element-of-set-list? x set) set)
        ((null? set) (cons x set))
        ((> x (car set)) (cons (car set) (adjoin-set x (cdr set))))
        ((< x (car set)) (cons x set))))

(define (union-set-list set1 set2)
  (cond [(null? set1) set2]
        [(element-of-set-list? (car set1) set2) (union-set-list (cdr set1) set2)]
        [else (union-set-list (cdr set1) (adjoin-set (car set1) set2))]))
#| END |#