プログラミング言語論 第2回レポート


  1. (Prolog)

    プリント第Ⅴ章 p.6 問5.4.2

    参考: 問5.4.1の解答例

    ?- append([1,2], [3,4], X).
    これに対して、 append([H1|X1], Y1, [H1|Z1]):- append(X1, Y1, Z1). が、
    H1=1, X1=[2], Y1=[3,4], X=[1|Z1] で適用できる。

    ?- append([2], [3,4], Z1).
    これに対して、 append([H2|X2], Y2, [H2|Z2]) :- append(X2, Y2, Z2). が、
    H2=2, X2=[], Y2=[3,4], Z1=[2|Z2] で適用できる。

    ?- append([], [3,4], Z2).
    これに対して、 append([], Y3, Y3). が、
    Y3=[3,4], Z2=[3,4] で適用できて、ゴール節が消える。

    まとめると、 X = [1|[2|[3,4]]] (= [1,2,3,4])

  2. (CPSへの変換)

    プリント第Ⅶ章 p.6 問7.4.1
    このHTMLファイルを元にして下さい。

  3. (型クラス)

    プリント第Ⅷ章 p.4 問8.5.1
      または
    プリント第Ⅷ章 p.5 問8.6.1
    どちらか1問を選択して下さい。


プログラミング言語特論のホームページ
Koji Kagawa