This is why I want to get them right, and I'm rewriting some basic functions related to lists.
First of all, a little explanation of lisp lists in general.
Lists are based on a more simple structure called "cons". A cons is just a pair. The only thing that can contain a cons in the first (car) or the second (cdr) cell are:
- string
- number
- symbol
- cons
First we'll see two axioms that must always be true related to conses.
(= x (car (cons x y)))
(= y (cdr (cons x y)))
Everything that guarantees this is a cons. Well, at least at this level...
a cons is represented by (x . y) , and a cons with another cons in the cdr would be (x . ( y . z))
A list is a special kind of cons with a determined structure.
( x . (y . (z . nil))) . A way to visually simplify this is ( x y z ) . That means that in a list of n elements, there are n conses linked through cdr's, with the last cdr pointing to nil. If you had to build (1 2 3) with conses, you could do it with (cons 1 (cons 2 (cons 3 nil))) .
Here I show the few scheme functions I wrote along with some explanations that davazp kindly gave me at #emacs-es and #lisp-es.
Theese are my first versions of some functions.
Here we see build-list can be abstracted to a more general (and easier to write) procedure called build-range, and I just call it with a start point = 1.
On the reverse function, we can use a different "happy idea".
Enough for today. Thanks to davazp and other #emacs-es -ers for their help and motivation.
No hay comentarios:
Publicar un comentario