Toggle navigation
Egison
ドキュメント
デモ
オンライン・デモ
ポーカーの役判定
麻雀の上がり判定
双子素数の列挙
ツリー
グラフ
3-SATを解く乱択アルゴリズム
時系列データ解析
オンライン・ツール
オンライン Egison
オンライン・チュートリアル
数式処理
ブログ
コミュニティ
ツリー
下記のプログラムは編集して実行できます。
def tree a := matcher | leaf $ as a with | Leaf $x -> [x] | Node _ _ -> [] | node $ $ as (a, multiset (tree a)) with | Leaf _ -> [] | Node $x $ts -> [(x, ts)] | $ :: $ as (a, tree a) with | Leaf _ -> [] | Node $x $ts -> map (\t -> (x, t)) ts | $ ++ $ as (list a, tree a) with | $tgt -> matchAll tgt as tree a with | loop $i (1, $n) ($x_i :: ...) $t -> (map (\i -> x_i) [1..n], t) | $ as something with | $tgt -> [tgt] def treeData := Node "Programming language" [Node "pattern-match-oriented" [Leaf "Egison"], Node "Functional language" [Node "Strictly typed" [Leaf "OCaml", Leaf "Haskell", Leaf "Curry", Leaf "Coq"], Node "Dynamically typed" [Leaf "Egison", Leaf "Lisp", Leaf "Scheme", Leaf "Racket"]], Node "Logic programming" [Leaf "Prolog", Leaf "Curry"], Node "Object oriented" [Leaf "C++", Leaf "Java", Leaf "Ruby", Leaf "Python", Leaf "OCaml"]] def ancestors x t := matchAllDFS t as tree eq with | $hs ++ leaf #x -> hs assertEqual "ancestors" (ancestors "Egison" treeData) [["Programming language", "pattern-match-oriented"], ["Programming language", "Functional language", "Dynamically typed"]] def descendants x t := matchAllDFS t as tree eq with | _ ++ #x :: _ ++ leaf $y -> y assertEqual "descendants" (descendants "Functional language" treeData) ["OCaml", "Haskell", "Curry", "Coq", "Egison", "Lisp", "Scheme", "Racket"]
実行
次に見てほしいもの...
次のデモデモンストレーション
トップに戻る
This website in other langauge:
English
,
日本語