合肥生活安徽新聞合肥交通合肥房產生活服務合肥教育合肥招聘合肥旅游文化藝術合肥美食合肥地圖合肥社保合肥醫院企業服務合肥法律

        代寫CMSC 323、代做Java/Python編程

        時間:2024-03-07  來源:合肥網hfw.cc  作者:hfw.cc 我要糾錯



        CMSC **3: Design and Implementation of Programming Languages
        HW 3: Functions that accept multiple arguments.
        Due Date: 03-07-24
        Total Points: 100
        1. Functions that Accept Multiple Arguments
        Start with the F1WAE interpreter (the version that uses subst. See starter code.), and extend
        the implementation to support any number of parameters to a function (including zero), and any
        number of arguments (including zero) in a function application:
         <FunDef> = {deffun {<id> <id>*} <FnWAE>}
         <FnWAE> = <num>
         | {+ <FnWAE> <FnWAE>}
         | {- <FnWAE> <FnWAE>}
         | {with {<id> <FnWAE>} <FnWAE>}
         | <id>
         | {<id> <FnWAE>*}
        Since you must change the F1WAE datatype, and since different people may change it in
        different ways, you must provide a parse function this time, which accepts a quoted expression
        and produces an FnWAE value. For parsing, assume that any symbol other than '+, '-, or 'with can
        be a function name for a function call. Also, you must provide a parse-defn function that takes one
        (quoted) deffun and produces a FunDef value.
        Some examples:
        (test (interp (parse `{f 1 2})
         (list (parse-defn `{deffun {f x y} {+ x y}})))
         3)
        (test (interp (parse `{+ {f} {f}})
         (list (parse-defn `{deffun {f} 5})))
         10)
        Hint: remember that the PLAIT language provides the following useful functions:
        map: takes a function and a list and applies the function to each element in the list, returning a list
        of results. For example, if sexps is a list of S-expressions to parse, (map parse sexps) produces a
        list of fnWAEs by parsing each S-expression.
        foldl: applies a function to an initial accumulated value and elements in a list, each time
        obtaining a new accumulated value.
        2
        pair: creates a tuple. Use fst and snd to access items in the pair.
        map2: applies a function, in order, to each pair of elements from two lists in “parallel,” forming a
        new list with the results.
        2. Errors
        At run-time, a new error is now possible: a function application with the wrong number of
        arguments. Your interp function should detect this mismatch and report an error that includes the
        words “wrong arity”.
        As with the interpreter from class, the free variable error is still also possible and must be
        detected. Your interp function should detect free variables and report an error that includes the
        words “free identifier”.
        A function will be ill-defined if two of its arguments <id>s were the same. To prevent this
        problem, your parse-defn function should detect this problem and report a “bad syntax” error. For
        example, (parse-defn `{deffun {f x x } x}) should report a “bad syntax” error, while (parse-defn
        `{deffun {f x y} x}) should produce a FunDef value.
        Similarly, your interpreter must check to see if the function in an application is defined before
        evaluating the arguments. If not, an “undefined function” error should be raised.
        Some examples:
        (test/exn (interp (parse `{with {x y} 1}) '()) "free identifier")
        (test/exn (interp (parse `{f 1 2}) (list (parse-defn `{deffun {f x x} {+ x x}}))) "bad syntax")
        (test/exn (interp (parse `{f x}) (list (parse-defn `{deffun {g a b c} c}))) "undefined function")
        (test/exn (interp (parse `{f 1}) (list (parse-defn `{deffun {f x y} {+ x y}}))) "wrong arity")
        Your interpreter must evaluate all the argument expressions in an application expression before
        signaling any arity errors. For example:
        (test/exn (interp (parse `{f x}) (list (parse-defn `{deffun {f a b c} c})))"free identifier")
        So overall, the order in which errors should be raised for a given function call is:
        • First, “bad syntax”
        • Second, “undefined function”
        • Third, any errors that are raised while evaluating arguments.
        • Fourth, “wrong arity”
        • Last, any errors that are raised while evaluating the function body.
        3
        If the list of definitions contains multiple definitions with the same name, use just the first one
        (ignoring the others). In particular, there is no overload in this language: if there are two
        definitions with the same name and different arities, the first definition is always used regardless.
        For example, if you have the following definitions and program:
        (test/exn (interp (parse `{f 3 4})
         (list (parse-defn `{deffun {f a} 5})
         (parse-defn `{deffun {f a b} {+ a b}})))
         "wrong arity")
        Since the first definition of f takes a single argument, this program should raise a “wrong arity”
        error. The fact that another definition for f that takes two argument exists doesn’t matter.
        Your interpreter and parser will not be given any other kinds of erroneous programs besides the
        ones described in this section.
        3. Handin Instructions
        • Provide definitions for parse, parse-defn, and interp, as above.
        • Include a contract and comments before each function.
        • Your submission must include your test cases. They should not be commented out.
        • Include your name as a comment in your submission file.
        • Save your homework file in the following format hw3<first_name><last_name>.
        請加QQ:99515681  郵箱:99515681@qq.com   WX:codehelp

        掃一掃在手機打開當前頁
      1. 上一篇:AERO20542代做、代寫Python/Java編程
      2. 下一篇:莆田鞋購買渠道(盤點10個莆田鞋微商前十名)
      3. 無相關信息
        合肥生活資訊

        合肥圖文信息
        急尋熱仿真分析?代做熱仿真服務+熱設計優化
        急尋熱仿真分析?代做熱仿真服務+熱設計優化
        出評 開團工具
        出評 開團工具
        挖掘機濾芯提升發動機性能
        挖掘機濾芯提升發動機性能
        海信羅馬假日洗衣機亮相AWE  復古美學與現代科技完美結合
        海信羅馬假日洗衣機亮相AWE 復古美學與現代
        合肥機場巴士4號線
        合肥機場巴士4號線
        合肥機場巴士3號線
        合肥機場巴士3號線
        合肥機場巴士2號線
        合肥機場巴士2號線
        合肥機場巴士1號線
        合肥機場巴士1號線
      4. 短信驗證碼 酒店vi設計 deepseek 幣安下載 AI生圖 AI寫作 aippt AI生成PPT 阿里商辦

        關于我們 | 打賞支持 | 廣告服務 | 聯系我們 | 網站地圖 | 免責聲明 | 幫助中心 | 友情鏈接 |

        Copyright © 2025 hfw.cc Inc. All Rights Reserved. 合肥網 版權所有
        ICP備06013414號-3 公安備 42010502001045

        主站蜘蛛池模板: 亚洲日韩精品一区二区三区无码| 狠狠色婷婷久久一区二区| 国产成人无码一区二区三区在线| 老熟女高潮一区二区三区| 亚洲视频一区在线| 精品国产AV一区二区三区| 国产大秀视频在线一区二区| 国产怡春院无码一区二区| 国产人妖视频一区在线观看| 一区二区三区高清在线| 国产在线无码一区二区三区视频| 亚洲熟妇av一区| 国产女人乱人伦精品一区二区| 亚洲性日韩精品一区二区三区| 精品国产亚洲一区二区在线观看 | 国产午夜精品一区二区三区| 久久久久人妻精品一区| 在线精品自拍亚洲第一区| 国产在线精品一区二区夜色 | 无码精品人妻一区| 亚洲无线码在线一区观看| 亚洲av色香蕉一区二区三区蜜桃| 在线免费视频一区| 国产成人精品一区二区秒拍 | 国产精品一区二区久久不卡| 亚洲一区二区三区深夜天堂| 精品国产一区二区三区免费看 | 无码av免费毛片一区二区| 一区二区三区在线看| 韩国一区二区视频| 一本岛一区在线观看不卡| 国产福利微拍精品一区二区| 国产成人精品无人区一区| 色一情一乱一伦一区二区三欧美| 超清无码一区二区三区| 亚洲AV无码一区二区三区牲色| 久久国产一区二区| 一区二区在线免费视频| 波多野结衣AV一区二区三区中文| 国产精品无码一区二区三级| 日本一区二区三区在线视频|