2015年1月2日金曜日

開発環境

計算機プログラムの構造と解釈[第2版](ハロルド エイブルソン (著)、ジュリー サスマン (著)、ジェラルド・ジェイ サスマン (著)、Harold Abelson (原著)、Julie Sussman (原著)、Gerald Jay Sussman (原著)、和田 英一 (翻訳)、翔泳社、原書: Structure and Interpretation of Computer Programs (MIT Electrical Engineering and Computer Science)(SICP))の5(レジスタ計算機での計算)、5.5(翻訳系)、5.5.5(翻訳したコードの例)、問題 5.38-a.を解いてみる。

その他参考書籍

問題 5.38-a.

コード(BBEdit, Emacs)

(define (spread-arguments operands)
  (let ((a (first-operand operands))
        (b (first-operand (rest-operands operands))))
    (let ((seq1 (compile a 'arg1 'next))
          (seq2 (compile b 'arg2 'next)))
      (preserving '(env arg1) seq1 seq2))))

0 コメント:

コメントを投稿