0

次のように定義されているデータ型シーケンスを使用したい:

 datatype 'a seq = Nil | Cons of 'a * (unit-> 'a seq);
 exception EmptySeq; 
 fun head(Cons(x,_)) = x | head Nil = raise EmptySeq; 
 fun tail(Cons(_,xf)) = xf() | tail Nil = raise EmptySeq;

関数を前後に反復するオプションが必要です。

   datatype direction = Back | Forward; 
   datatype 'a bseq =   bNil | bCons of 'a * (direction -> 'a bseq);

そして、私もそれらを定義しました:

fun bHead(bCons(x,_)) = x | bHead bNil = raise EmptySeq; 
fun bForward(bCons(_,xf)) = xf(Forward) | bForward bNil = raise EmptySeq; 
fun bBack(bCons(_,xf)) = xf(Back) | bBack bNil = raise EmptySeq;

今、私がやろうとしているのは、int「k」を取得し、前後に反復できる無限シーケンスを返す関数「create_seq」を作成することです。例えば:

 - create_seq 2; 
val it = bCons (2,fn) : int bseq 
- bForward it; 
val it = bCons (3,fn) : int bseq 
- bForward it; 
val it = bCons (4,fn) : int bseq 
- bBack it; 
val it = bCons (3,fn) : int bseq 
- bBack it; 
val it = bCons (2,fn) : int bseq 
- bBack it; 
val it = bCons (1,fn) : int bseq 
- bBack it; 
val it = bCons (0,fn) : int bseq 
- bBack it; 
val it = bCons (~1,fn) : int bseq

これは私がやろうとしてきたことであり、なぜうまくいかないのかわかりません:

fun create_seq k = (k,fun check Forward = create_seq(k+1) 
| check Back = create_seq(k-1));

これも:

fun create_seq k = (k,fn x => case x of Forward => create_seq(k+1)
                       | Back => create_seq(k-1));

またはこれさえ:

fun create_seq k = (k,fn Forward => create_seq(k+1)
                       | Back => create_seq(k-1));
4

1 に答える 1

0

コンストラクタを忘れたようです:

fun intbseq(k:int) = bCons(k,fn Forward => intbseq(k+1)| Back => intbseq(k-1));

これはうまくいくはずです。

于 2014-05-30T05:43:11.780 に答える