• 検索結果がありません。

プログラミング言語意味論( 2016 年度)・テスト問題用紙

N/A
N/A
Protected

Academic year: 2021

シェア "プログラミング言語意味論( 2016 年度)・テスト問題用紙"

Copied!
8
0
0

読み込み中.... (全文を見る)

全文

(1)

プログラミング言語意味論 ( 2016 年度) ・テスト問題用紙

(2017 年 02 月 09 日(水) ・ 08:50 〜 9:35)

解答上、その他の注意事項

I.

問題は、問

I〜III

まである。

II.

解答用紙の右上の欄に学籍番号・名前を記入すること。

III.

ノート・プリント・参考書などは持ち込み可である。

IV.

携帯電話などの通信機能を持つもの及び

PC

は 持ち込み不可 である。

V.

テストの配点は

50

点(+ボーナス

20

点)である。合格はレポートの得点を加点して、

100

点満点中

60

点以上とする。

1

(2)

I. (ラムダ計算) (12点×2) 次のλ式が正規形に到達するまでの、最左戦略による1ステップずつのβ簡約の列を書け。た だし、5回以内の最左戦略によるβ簡約で正規形に到達しない式については、それが判別でき る時点(以前と同じ式が出現した時点)、または5回β簡約した時点で止めてよい。

解答例1:

f x.f(f x))((λf x.f(f x))g)y

−→β (λx.((λf x.f(f x))g)(((λf x.f(f x))g)x))y

−→β ((λf x.f(f x))g)(((λf x.f(f x))g)y)

−→βx.g(gx))(((λf x.f(f x))g)y)

−→β g(g(((λf x.f(f x))g)y))

−→β g(g((λx.g(gx))y))

−→β g(g(g(gy)))

解答例2:

x.xx)(λx.xx)

−→β (λx.xx)(λx.xx)

−→β (停止しない)

(1) (λab.ba)(λgx.gx)(λgy.g(gy))

(2) (λt.t(λab.b))((λxyg.gxy)(λf x.f x)(λf x.x))

なお、必要に応じてI ≡λx.xなど適宜、定数を定義しても良い。

2

(3)

II. (語句) (13点×2) プログラミング言語(やその処理系)で用いられる次の6つの語句のうち2つを選択し、ソー スコードなど、具体的な例を挙げて説明せよ。ただし、講義プリントにのっている例ではなく、

オリジナル の例を考えること。

遅延評価(lazy evaluation)

参照透明性(referential transparency)

非決定性(nondeterminism)

• 接続 (あるいは継続)(continuation)

• CPS (continuation passing style)

III. (自由記述—ボーナス問題) (最高20点)

巷では、小・中学生に対するプログラミング教室が盛んになっている。あなたも、春休みに叔父 さん、叔母さんの家に一泊二日で行って、小学6年生のいとこに「プログラミングの神髄」を 教える家庭教師のアルバイトをすることになった。ここで「プログラミングの神髄」とは特定 のプログラミング言語やプラットフォームによらない、プログラミングの背後にある考え方を いう。

あなたなら、どのような題材を選んで、どのように教えるか?計画を立てよ。なお、叔父さん、

叔母さんは金に糸目をつけなくても良い、と言っている。

3

(4)
(5)

プログラミング言語意味論 (2016 年度) ・テスト解答用紙 (2017 年

02

09

日)

学籍番号 氏名

(6)
(7)

学籍番号 氏名

(8)

参照

関連したドキュメント

 本実験の前に,林間学校などで行った飯 はん 盒 ごう 炊 すい

2021] .さらに対応するプログラミング言語も作

それから 3

町の中心にある「田中 さん家」は、自分の家 のように、料理をした り、畑を作ったり、時 にはのんびり寝てみた

Ⅲで、現行の振替制度が、紙がなくなっても紙のあった時に認められてき

下山にはいり、ABさんの名案でロープでつ ながれた子供たちには笑ってしまいました。つ

3 月 11 日、 お母さんとラーメン屋さんでラーメンを食べているときに地震が起こっ