|  car list First element of list. | 
>(car '(1 2 3))
1
 | 
  
    |  cdr list Remainder of list. | 
>(cdr '(1 2 3))
(2 3)
 | 
  
    |  caar list Equivalent to (car (car list)). | 
>(caar '((1 2) 3 4))
1
 | 
  
    |  cadr list Equivalent to (car (cdr list)). | 
>(cadr '((1 2) 3 4))
3
 | 
  
    |  cddr list Equivalent to (cdr (cdr list)).  Note thatcdaris not part of Arc. | 
>(cddr '((1 2) 3 4))
(4)
 | 
  
    |  conswhen f x y Cons xandyif(f x)is true.  Otherwise returnsy. | 
>(conswhen (fn (_) (< (len _) 3)) '(1 2) '(3 4 5))
((1 2) 3 4 5)
 
>(conswhen (fn (_) (< (len _) 3)) '(1 2 3 4) '(3 4 5))
(3 4 5)
 | 
  
    |  consif x list Cons xontolistifxis notnil. | 
>(consif 1 '(2 3))
(1 2 3)
 
>(consif nil '(2 3))
(2 3)
 | 
  
    |  firstn n list Returns the first nelements oflist. | 
>(firstn 3 '(1 2))
(1 2)
 
>(firstn 3 '(a b c d e))
(a b c)
 | 
  
    |  nthcdr n list Returns listafter skipping the firstnelements. | 
>(nthcdr 0 '(1 2 3))
(1 2 3)
 
>(nthcdr 2 '(1 2 3))
(3)
 
>(nthcdr 10 '(1 2 3))
nil
 | 
  
    |  last list Returns the last element of list. | 
>(last '(1 2 3))
3
 | 
  
    |  flat list Flattens listinto a list of atoms.  Anynils are removed. | 
>(flat '(1 2 () (3 4 (5))))
(1 2 3 4 5)
 | 
  
    |  rev list Reverses list. | 
>(rev '(1 2 3))
(3 2 1)
 
>(rev '(1 (2 3) 4))
(4 (2 3) 1)
 | 
  
    |  carif x Returns (car x)ifxis a list, and returnsxotherwise.  This provides a 'safe' way to return the first element of something that may or may not be a list. | 
>(carif '(1 2))
1
 
>(carif 3)
3
 | 
  
    |    caris x val Tests if xis a list and(car x)isval. | 
>(caris '(1 2) 1)
t
 
>(caris 1 1)
nil
 | 
  
    |  intersperse x list Inserts xbetween elements oflist.  Iflisthas fewer than 2 elements, there is no effect. | 
>(intersperse 1 '(a b (c d) e))
(a 1 b 1 (c d) 1 e)
 
>(intersperse nil '(1 2 3))
(1 nil 2 nil 3)
 | 
  
    |  split list pos Splits listinto two lists at the given position, which must be no more than the length of the list. | 
>(split '(a b c) -1)
((a b) (a b c))
 
>(split '(a b c) 0)
(nil (a b c))
 
>(split '(a b c) 1)
((a) (b c))
 
>(split '(a b c) 2)
((a b) (c))
 
>(split '(a b c) 3)
((a b c) nil)
 | 
  
    |  pair list [f] Splits listinto pairs.  By default, each pair is made into a list.  If specified, function f is applied to each pair. | 
>(pair '(a b c d))
((a b) (c d))
 
>(pair '(a b c d e))
((a b) (c d) (e))
 
>(pair '(1 2 3 4) +)
(3 7)
 
>(pair '(10 2 3 40 50 6) max)
(10 40 50)
 | 
  
    |  tuples list [n] Splits listinto groups ofn.tuplesis a generalization ofpair. | 
>(tuples '(1 2 3 4 5) 1)
((1) (2) (3) (4) (5))
 
>(tuples '(1 2 3 4 5))
((1 2) (3 4) (5))
 
>(tuples '(1 2 3 4 5) 3)
((1 2 3) (4 5))
 | 
  
    |  join [list ...] Joins lists into one list. | 
>(join '(1 2) nil '(3 4))
(1 2 3 4)
 | 
  
    |  list [arg ...] Creates a list of the arguments. | 
>(list 1 2 3)
(1 2 3)
 
>(list "a" '(1 2) 3)
("a" (1 2) 3)
 | 
  
    |  copylist args Identical to list. | 
>(copylist '(1 2 3))
(1 2 3)
 
>(copylist '("a" (1 2) 3))
("a" (1 2) 3)
 | 
  
    |  range start end Creates a list of numbers from start to end in steps of 1.  The last number is <= end. | 
>(range 0 10)
(0 1 2 3 4 5 6 7 8 9 10)
 
>(range 1.5 3.8)
(1.5 3)
 | 
  
    |  n-of n expr Evaluates exprntimes and returns a list of the results. | 
>(n-of 5 "a")
("a" "a" "a" "a" "a")
>(w/instring ins "abcdefg" (n-of 5 (readc ins)))
(#\a #\b #\c #\d #\e)
 | 
  
    |  adjoin elt list [test] Cons eltontolistunless(test elt y)is true for someyinlist.  By default,testisiso, soeltwill be joined if it is not present inlist. | 
>(adjoin 2 '(1 2 3))
(1 2 3)
 
>(adjoin 2 '(1 3 5))
(2 1 3 5)
 
>(adjoin 2 '(1 2 3) <)
(1 2 3)
 
>(adjoin 2 '(0 1 2) <)
(2 0 1 2)
 | 
  
    |    counts list [table] Counts how many times each element of listoccurs.  The results are returned as a table mapping from the element to the count.  If a table is passed in, it will be updated. | 
>(counts '(b a n a n a))
#hash((a . 3) (b . 1) (n . 2))
 
>(let tl (table)
  (counts '(1 2) tl)
  (counts '(1 3) tl))
#hash((1 . 2) (2 . 1) (3 . 1))
 | 
  
    |  commonest list Returns the element of listoccurring most frequently, along with its count. | 
>(commonest '(b a n a n a))
(a 3)
 
>(commonest nil)
(nil 0)
 | 
  
    |  reduce f list Reduces listusingf.  Appliesfto the first two elements oflist.  Then recursively appliesfto that result and the next element oflist. | 
>(reduce + '(1 2 3 4 5))
15
 
>(reduce + '("a" "b" "c"))
"abc"
>(reduce / '(1 2 3))
1/6
 | 
  
    |  rreduce f list Reduces listusingfin reverse.  Appliesfto the last two elements oflist.  Then recursively appliesfto that result and the previous element oflist. | 
>(rreduce + '(1 2 3 4 5))
15
 
>(rreduce / '(1 2 3))
3/2
 | 
  
    |  retrieve n f list Returns the first nelements oflistfor which predicatefis true.  Renamed from firstn-that in arc3. | 
>(retrieve 3 odd '(1 2 3 4 5 6 7 8))
(1 3 5)
 
>(retrieve 3 odd '(2 4 6 8))
nil
 | 
  
    |  most f list Returns the element of listfor which rating functionfreturns the largest value. | 
>(most len '("cat" "bird" "dog"))
"bird"
>(most abs '(3 -10 5))
-10
 
>(most abs '(-1 1 -1))
-1
 | 
  
    |  map1 f list Applies fto the elements oflist.  The results are cons'd together into a list. | 
>(map1 (fn (_) (list _ (* _ 10))) '(1 2 3))
((1 10) (2 20) (3 30))
 
>(map1 cdr '((1) (2 3) (4 5)))
(nil (3) (5))
 | 
  
    |  mappend f [list ...] Maps fon the arguments, and then joins the results together.fmust return a list.nilresults are omitted. | 
>(mappend (fn (_) (list _ (* _ 10))) '(1 2 3))
(1 10 2 20 3 30)
 
>(mappend cdr '((1) (2 3) (4 5)))
(3 5)
 | 
  
    |  reclist f list Recursively applies f to tail subsequences of listand returns the first true result.  Returnsnilif none. | 
>(reclist (fn (x) (prn x) nil) '(a b c))
(a b c)
(b c)
(c)
nil
 
>(reclist (fn (_) (if (is (len _) 2) _)) '(a b c))
(b c)
 | 
  
    |  mem test list Tests elements of list.  If test is true for an element, returns the remainder of the list from that point. testis either an element or a predicate. | 
>(mem (fn (_) (odd _)) '(2 4 5 6 7))
(5 6 7)
 
>(mem 6 '(2 4 5 6 7))
(6 7)
 | 
  
    |  trues f list Maps function fontolistand returns only the true (non-nil) values. | 
>(trues cdr '((1 2) (3) (4 5)))
((2) (5))
 
>(trues (fn (_) (if (odd _) (* 10 _))) '(1 2 3 4 5))
(10 30 50)
 | 
  
    |    sref seq value index Sets indexed entry in a list, string, or hash table to
  the given value. | 
>(let x (copy "abc")  ; make the string literal mutable
    (sref x #\d 1) x)
"adc"
>(do
    (= x '(1 2 3))
    (sref x 4 1) x)
(1 4 3)
 | 
  
    |  count test seq Counts the number of elements of seqthat satisfytest.testis an object or predicate.  For a table, the elements are the values. | 
>(count #\a "banana")
3
 
>(count (fn (_) (odd _)) '(1 2 3 4 5))
3
 | 
  
    |  union f xs ys Takes union of sequence xsandys.  Predicatefis used to determine equality to filter out duplicates.xsandysmust both be lists or strings. | 
>(union is '(1 2 3) '(2 3 4))
(1 2 3 4)
 
>(union is "ab" "banana")
"abnn"
 
>(union (fn (a b) (is (mod a 10) (mod b 10))) '(1 2 3) '(13 24 35))
(1 2 3 24 35)
 | 
  
    |  len seq Computes the length of seq. | 
>(len "abc")
3
 
>(len '(1 2 3))
3
 
>(len (obj a 1 b 2))
2
 | 
  
    |    len< seq n Tests if length of seqis less thann. | 
>(len< "abc" 4)
t
 
>(len< '(1 2 3) 4)
t
 
>(len< (obj a 1 b 2) 4)
t
 | 
  
    |    len> seq n Tests if length of seqis greater thann. | 
>(len> "abc" 4)
nil
 
>(len> '(1 2 3) 4)
nil
 
>(len> (obj a 1 b 2) 4)
nil
 | 
  
    |  dedup seq Returns contents of seqwithout duplicates.  For a string, returns a list of characters.  For a table, returns a list of values. | 
>(dedup '(1 2 3 2 1))
(1 2 3)
 
>(dedup "abcba")
(#\a #\b #\c)
 
>(dedup (obj a 1 b 2 c 1))
((a 1) (b 2) (c 1))
 | 
  
    |    single list Returns true if given a list of length one. | 
>(single '(1))
t
 
>(single 1)
nil
 
>(single '())
nil
 | 
  
    |  pos test seq [start] Returns the index of the first element of seqthat satisfiestest.seqis a list or string.testis either an object or predicate function.  Ifstartis given, testing starts at that element. | 
>(pos 'c '(a b c d))
2
 
>(pos #\c "abcd")
2
 
>(pos #\c "abcdc" 3)
4
 
>(pos odd '(2 4 5 6 7))
2
 
>(pos odd '(2 4 6))
nil
 | 
  
    |    before t1 t2 seq [start] Tests if t1is true beforet2inseq.seqis either a list or string.  The tests are either objects or predicate functions.  Ifstartis given, search starts with the specified element. | 
>(before 4 odd '(2 4 1 3))
t
 
>(before 4 odd '(2 3 4 1))
nil
 
>(before #\a #\n "banana")
t
 
>(before #\a #\n "banana" 2)
nil
 | 
  
    |  rand-elt seq Returns a random element from a list, or a random character from a string.  It also works on a table with integer keys from 0 to n.  Renamed from random-elt in arc3. | 
>(rand-elt '(1 2 3))
2
 
>(rand-elt "abcd")
#\d
 | 
  
    |  mismatch s1 s2 Compares sequences and returns the position of the
first mismatch (as determined by is).  Returnsnilif
the sequences are identical. | 
>(mismatch "abcde" "abXde")
2
 
>(mismatch '(1 2 3) '(1 9 3))
1
 
>(mismatch "abc" "abc")
nil
 | 
  
    |  find test seq Finds and returns the first element of seqthat satisfiestest(object or predicate).seqcan be a list or string. | 
>(find odd '(2 3 4 5))
3
 
>(find odd '(2 4 6))
nil
 
>(find alphadig "...abc...")
#\a
 | 
  
    |  cut seq start [end] Returns subsequence of seqfromstarttoend.  Ifendis not specified,  the remainder ofseqis used.  The seq can be a list or string. | 
>(cut "abcde" 2)
"cde"
 
>(cut "abcde" 2 4)
"cd"
 
>(cut '(a b c d) 2)
(c d)
 
>(cut '(a b c d) 2 4)
(c d)
 | 
  
    |  rem test seq Removes elements from seqthat satisfytest.testis either a function or an object.seqis either a list or string. | 
>(rem odd '(1 2 3 4 5))
(2 4)
 
>(rem 3 '(1 2 3 4 5))
(1 2 4 5)
 
>(rem #\c "abcde")
"abde"
 
>(rem (fn (_) (in _ #\a #\b)) "abcde")
"cde"
 | 
  
    |  keep test seq Keeps elements from seqthat satisfytest.testis either a function or an object.seqis either a list or string. | 
>(keep odd '(1 2 3 4 5))
(1 3 5)
 
>(keep 3 '(1 2 3 4 5))
(3)
 
>(keep #\c "abcde")
"c"
 
>(keep (fn (_) (in _ #\a #\b)) "abcde")
"ab"
 | 
  
    |  map f [seq ...] Applies fto the elements of the sequences, taking the first from each, the second from each, and so on.  If there arensequences,fmust be a function acceptingnarguments.  The sequences can be lists or strings.  If any sequence is a string, thenfmust return a character, and the result will be a string made up of the results fromf.  Otherwise, the result will be a list of the results fromf.  The sequences are processed up to the length of the shortest sequence.  For a single list,mapis the same asmap1. | 
>(map (fn (a b c) (+ (* a 100) (* b 10) c))
  '(1 2 3) '(4 5 6) '(7 8 9 10))
(147 258 369)
 
>(map (fn (_) (list _ (* _ 10))) '(1 2 3))
((1 10) (2 20) (3 30))
 
>(map cdr '((1) (2 3) (4 5)))
(nil (3) (5))
 
>(map (fn (c n) (coerce (+ n (coerce c 'int)) 'char)) "abc" '(0 2 4))
"adg"
 
>(map min "bird" "elephant")
"bied"
 | 
  
    |  sum f seq Applies f to the elements of the sequence and sums the results.  New in arc3. | 
>(sum int "abc")
294
 
>(sum log '(1 2 3))
1.791759469228055
 
>(sum cadr (obj a 1 b 2 c 3))
6
 | 
  
    |  get index Generates a function to get the element referenced by index; the function can be applied to a table.  This is useful for mapping, for instance.  (It can also be applied to functions, not just sequences.) New in arc3. | 
>(map get.2 '((a b c) (1 2 3) (p q r)))
(c 3 r)
 
>(get!b (obj a 10 b 20))
20
 
>(get.42 log)
3.7376696182833684
 | 
  
    |  rand-choice expr [...] Randomly choose one of the expressions. | 
>(rand-choice "a" 42 '(1 2 3))
(1 2 3)
 | 
  
    |  compare comparer scorer Creates a procedure on two values that applies scorerto each value, and then appliescomparerto the two scores. | 
>(compare < len)
#<procedure: compare>
 
>((compare < len) "yz" "abc")
t
 | 
  
    |  only f Creates a procedure that will apply fto its arguments only if there are arguments. | 
>(only +)
#<procedure: only>
 
>((only +) 1 2 3)
6
 
>((only +))
nil
 | 
  
    |  accum accfn [body ...] Executes body.  Inside body, each time accfn is called, its argument is pushed on a list that becomes the return value. | 
>(accum accfn (each x '(1 2 3) (accfn (* x 10))))
(10 20 30)
 | 
  
    |  summing sumfn [body ...] Sums the number of times sumfn is called with a true argument in body.  The sum is returned.  The sumfn argument specifies the name under which the summing function is available to the body. | 
>(summing istrue (map istrue '(1 nil nil t)))
2
 | 
Copyright 2008 Ken Shirriff.