I've been trying to grow trees (not really deliberately...) a bit like this:
  ("0"
    ("00"
      ("000"
        ("0000" "0001"))
      ("001"
        ("0000" "0001" "0002" "0003"))
      ("002"
        ("0000" "0001" "0002" "0003"))
      ("003"
        ("0000" "0001" "0002" "0003"))
      ("004"
        ("0000" "0001" "0002" "0003"))
      ("005"
        ("0000" "0001" "0002")))
    ("01"
      ("000"
        ("0000" "0001" "0002"))
      ("001"
        ("0000" "0001" "0002"))
      ("002"
        ("0000" "0001" "0002" "0003" "0004")))
    ("02"
      ("000"
        ("0000" "0001" "0002"))
      ("001"
        ("0000" "0001" "0002"))
      ("002"
        ("0000" "0001" "0002")))))
I think that's right. What I want to do is to locate an element and find its 'address'. I can do this:
;-> (2 3 1 4)
but I really want to produce is this:
- kind of like a series of signposts... Any suggestions?
			
			
			
				I don't see the logic of:
Do you mean the node branch points leading to "0004" ? that would be:
and you can get those by successively chopping of the last member in the found index vector and replacing it with 0:
(l (append (chop v 1) '(0))) => "0000"
(l (append (chop v 2) '(0))) => "002"
(l (append (chop v 3) '(0))) => "01"
(l (append (chop v 4) '(0))) => "0"
; or all in one shot
(map (fn (i) (l (append (chop v i) '(0)))) (sequence 1 (length v)))
=> ("0000" "002" "01" "0")
Lutz
			
			
			
				Almost!
The 'chop' sequence needed is:
(l (append (chop v 2) '(0))) --> "002"
(l (append (chop v 3) '(0))) --> "01"
(l (append (chop v 4) '(0))) --> "0"
The following seems to work:
			
			
				Thanks! I knew you guys could see the wood through the trees! 
I'm not sure exactly what I'm doing, but you're helping me do it, anyway.. ;-)
			
			
			
				Hi cormullion,
Quote from: "cormullion"
I'm not sure exactly what I'm doing, but you're helping me do it, anyway.. ;-)
I knew you and I were in the same 
m i c h a e l
P.S. Congratulations on winning the t-shirt!