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

        代寫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. 無相關信息
        合肥生活資訊

        合肥圖文信息
        挖掘機濾芯提升發動機性能
        挖掘機濾芯提升發動機性能
        戴納斯帝壁掛爐全國售后服務電話24小時官網400(全國服務熱線)
        戴納斯帝壁掛爐全國售后服務電話24小時官網
        菲斯曼壁掛爐全國統一400售后維修服務電話24小時服務熱線
        菲斯曼壁掛爐全國統一400售后維修服務電話2
        美的熱水器售后服務技術咨詢電話全國24小時客服熱線
        美的熱水器售后服務技術咨詢電話全國24小時
        海信羅馬假日洗衣機亮相AWE  復古美學與現代科技完美結合
        海信羅馬假日洗衣機亮相AWE 復古美學與現代
        合肥機場巴士4號線
        合肥機場巴士4號線
        合肥機場巴士3號線
        合肥機場巴士3號線
        合肥機場巴士2號線
        合肥機場巴士2號線
      4. 幣安app官網下載 短信驗證碼

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

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

        主站蜘蛛池模板: 精品国产高清自在线一区二区三区| 中文字幕精品一区| 国产一区二区三区小说| 在线中文字幕一区| 国产成人综合一区精品| 免费一区二区三区四区五区| 久99精品视频在线观看婷亚洲片国产一区一级在线 | 人妻AV一区二区三区精品| 精品国产乱子伦一区二区三区 | 日韩好片一区二区在线看| AA区一区二区三无码精片| 午夜视频一区二区| 国产品无码一区二区三区在线蜜桃| 无码人妻少妇色欲AV一区二区 | 国产主播一区二区三区| 国产午夜精品一区理论片| 人妻av综合天堂一区| 国产一区二区精品久久凹凸| 乱色精品无码一区二区国产盗| 日本福利一区二区| 亚洲AV成人一区二区三区AV| 日本人的色道www免费一区| 亚洲国产精品一区二区久久hs| 日韩伦理一区二区| 美女啪啪一区二区三区| 日本精品一区二区三区视频| 美女一区二区三区| 波多野结衣一区二区三区88| 性无码免费一区二区三区在线| 国产精品亚洲专区一区| 乱色精品无码一区二区国产盗| av无码精品一区二区三区四区| 国产91精品一区二区麻豆网站| 亚洲一区二区三区免费| 日韩精品电影一区| 国产91久久精品一区二区 | 欲色aV无码一区二区人妻 | 亚洲日本乱码一区二区在线二产线 | 国产精品一区二区AV麻豆| 日韩高清国产一区在线| 国产高清精品一区|