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-14

QiでL-99 (P11 連続する要素をランレングス圧縮する その2)

| 23:29 | QiでL-99 (P11 連続する要素をランレングス圧縮する その2) - わだばLisperになる を含むブックマーク はてなブックマーク - QiでL-99 (P11 連続する要素をランレングス圧縮する その2) - わだばLisperになる

実は本家サイトのP-99はPrologの全問解答がありますが、L-99は解答が全部揃ってません。

そういう訳で、fixdapにてL-99の解答を作成するというプロジェクトを作成してみたんですが、良かったら投稿してみて下さい!

現在作成したCommon Lisp、Scheme、Arc、Qi等の解答例を少しずつアップしてみています。

(encode-modified [a a a a b c c a a d e e e e])
\=>[[4 a] b [2 c] [2 a] d [4 e]]
\

(define encode-modified
    X -> (encode-modified* (pack X)))

(define encode-modified*
    [ ] -> [ ]
    [H | T] -> [(head H) | (encode-modified* T)] where (= 1 (length H))
    [H | T] -> [[(length H) (head H)] | (encode-modified* T)])