0
私は、次のデータ型を使用してバイナリ検索ツリーを作成するためのガイドに従ってきました:Haskell - 再帰を使用する代数データ型ですか?
data BinarySearchTree a = EmptyTree | TreeNode a (BinarySearchTree a) (BinarySearchTree a) deriving (Show, Read, Eq)
私はすなわち、「ツリーノード」は、再帰を使用していると言ってに修正AMは、独自のデータ型「(の2つの要素を作成しますBinarySearchTree a)(BinarySearchTree a) '?
私はこのようなデータ型を見たことがない、簡単な説明は素晴らしいだろう!
リストタイプ(これは再帰的でもあります)と非常に似ていますが、1回ではなく2回繰り返される点が異なります(リスト内のセルには1つのテールしかありません) 。 – chi
技術的には、 'TreeNode' *は2つの' BinarySearchTree'値( 'a'値)を取り、*新しい' BinarySearchTree'値を返します。 *型*は再帰的に定義されます。 – chepner
TreeNodeは*何も作成しません。 – immibis