Hatena::Groupcadr

わだばLisperになる このページをアンテナに追加 RSSフィード

2004 | 12 |
2005 | 01 | 02 | 07 | 10 | 11 |
2006 | 06 | 07 | 08 | 09 | 10 | 11 | 12 |
2007 | 01 | 02 | 03 | 04 | 05 | 06 | 07 | 08 | 09 | 10 | 11 | 12 |
2008 | 01 | 02 | 03 | 04 | 05 | 06 | 07 | 08 | 09 | 10 | 11 | 12 |
2009 | 01 | 02 | 03 | 04 | 05 | 06 | 07 | 08 | 09 | 10 | 11 | 12 |
2010 | 01 | 02 | 03 | 04 | 05 | 06 | 07 | 08 | 09 | 10 | 11 | 12 |
2011 | 01 | 02 | 03 | 04 | 05 | 06 | 07 | 11 |

2008-03-11

QiでL-99 (P09 連続して現われる要素を纏める)

| 16:47 | QiでL-99 (P09 連続して現われる要素を纏める) - わだばLisperになる を含むブックマーク はてなブックマーク - QiでL-99 (P09 連続して現われる要素を纏める) - わだばLisperになる

ちょっと複雑になると途端にどうしたら良いか分からなくなってしまいます。

そろそろチュートリアルをきちんと読まねば…。

(pack [a a a a b c c a a d e e e e])
\=> [[a a a a] [b] [c c] [a a] [d]]
\

(define pack
    [ ] -> [ ]
    X -> (pack* X [ ] [ ]))

(define pack*
    [ ] Acc Res -> (reverse (cons Acc Res))
    [H | T] Acc Res -> (pack* T (cons H Acc) Res) where (or (empty? Acc) (= H (head Acc)))
    Lst Acc Res -> (pack* Lst [ ] (cons Acc Res)))