Next: Constructing Recursive Data Structures:
Up: Adding Computation Domains: CLP
Previous: Constructing Recursive Data Structures
-
data:image/s3,"s3://crabby-images/845e5/845e5653117ceef67150ec94120aac9153b5499d" alt="$\mbox{$\bullet$}$"
- Lists:
- A nonempty list is a head followed by a tail (another list)
- Or the empty list (nil)
-
data:image/s3,"s3://crabby-images/845e5/845e5653117ceef67150ec94120aac9153b5499d" alt="$\mbox{$\bullet$}$"
- The functor name usually associated with lists is `.'
-
data:image/s3,"s3://crabby-images/845e5/845e5653117ceef67150ec94120aac9153b5499d" alt="$\mbox{$\bullet$}$"
- The constant name used to denote the empty list is []
-
data:image/s3,"s3://crabby-images/845e5/845e5653117ceef67150ec94120aac9153b5499d" alt="$\mbox{$\bullet$}$"
- E.g., .(a, .(b, .(c, []))) is the list comprised by the
elements a, b, and c
-
data:image/s3,"s3://crabby-images/845e5/845e5653117ceef67150ec94120aac9153b5499d" alt="$\mbox{$\bullet$}$"
- When some term is a list:
-
- is_list([]).
is_list(.(Head, Tail)):- is_list(Tail).
Last modification: Thu Oct 7 12:04:03 MEST 1999 <webmaster@clip.dia.fi.upm.es>