[試題] 102-1 穆信成 程式語言 期中考

看板NTU-Exam作者 ( )時間10年前 (2013/11/08 23:29), 編輯推噓0(001)
留言1則, 1人參與, 最新討論串1/1
課程名稱︰程式語言 課程性質︰選修 課程教師︰穆信成 開課學院:管理學院 開課系所︰資訊管理學系 考試日期(年月日)︰11/7 (四) 考試時限(分鐘):9:10-12:10 是否需發放獎勵金:是 (如未明確表示,則不予發放) 試題 : (考試允許攜入任何講義/筆記/參考資料. 原試卷中斜體/程式字以高亮標示) Programming Languages: Midterm Examination Shin-Cheng Mu Nov. 7, 2013 You may assume that knowledge about arithmetic (e.g. ( ×) is associative, multiplication distributes over addition, etc) need no further proof and may be taken as axioms. Algebraic proofs or derivations need not be carried out in glory details -- you may skip some steps that you think are trivial. Do label the important steps, however, especially the step(s) where you use induction. You can use all Haskell functions in the standard prelude, mentioned in the lectures. 1. (10 points) A suffix of a list xs is a consecutive segment of xs that ends at the right end of xs. Define a function lmamrm :: [Int] → Int such that lmamrm xs returns the num- ber of suffixes of xs whose leftmost element is less than or equal to its rightmost element. (The funny name lmamrm stands for ``leftmost-at-most-rightmost".) For example, [4, 3, 9, 3] has two such suffixes: [3, 9, 3] and [3], thus lmamrm [4, 3, 9, 3] = 2. Hints: 1. A one-line definition will do. 2. we have already mentioned a function, in the standard library, that returns all suffixes of a list. 3. A list must be non-empty to have a leftmost and a rightmost element - which could be the same element. There was a function in the standard library check- ing whether a list is empty. If you cannot find it, define your own. 2. (15 points) Prove the property: sum。map (y ×) = (y ×)。sum 3. (15 points) Recall the definition of (!!) such that xs !! n yields the nth element in xs (counting from 0): (!!) :: [a] → Nat → a (x : xs) !! 0 = x (x : xs) !! (1+ n) = xs !! n. Consider the definition below geo :: Int → [Int] geo y = 1 : map (y ×) (geo y). n Prove that geo y !! n = y for all n :: Nat. 4. (15 points) An interleaving of two lists xs and ys is a permutation of the elements of both lists such that the mem- bers of xs appear in their original order, and so does the member of ys. Define interleave :: [a] → [a] → [[a]] such that interleave xs ys is the list of interleaving of xs and ys. For example, interleave [1, 2, 3] [4, 5] yields: [[1,2,3,4,5], [1,2,4,3,5], [1,2,4,5,3], [1,4,2,3,5], [1,4,2,5,3], [1,4,5,2,3], [4,1,2,3,5], [4,1,2,5,3], [4,1,5,2,3], [4,5,1,2,3]]. Hint: I would use an inductive definition. 5. A list ys is a sublist of xs if we can obtain ys by remov- ing zero or more elements from xs. For example, [2, 4] is a sublist of [1, 2, 3, 4], while [3, 2] is not. The list of all sublists of [1, 2, 3] is: [[], [3], [2], [2,3], [1], [1,3], [1,2], [1,2,3]]. (a) (20 points) Define a function sublist :: [a] → [[a]] that computes the list of all sublists of the given list. Hint: to form a sublist of xs, each element of xs could either be kept of dropped. (b) (10 points) Define a function maximumBy :: (a → Int) → [a] → a such that maximumBy f takes a (non-empty) list xs as its input, and returns an element x such that x is an element of xs and, for all element y in xs, f x ≧ f y. Hint: there are many ways to define maximumBy. I would perhaps go for an inductive definition. (c) (5 points) Let Item be some datatype, representing cer- tain items, for which two functions are defined: value :: Item → Int, weight :: Item → Int. Define two functions valList :: [Item] → Int and weightList :: [Item] → Int that respectively compute the total value and weight, give a list of items. (d) (10 points) Recall the 0-1 knapsack problem: given a list of items, we want to pick a sublist of the items that is as valuable as possible, whose total weight is no more than a weight limit. Give a one-line program knapsack :: Int → [Item] → [Item] knapsack w ... where w is the weight limit, that specifies (or, computes) the 0-1 knapsack problem, using the functions defined above, together with some library functions. It is only a specification, thus it does not matter if it is very slow. (We will learn how to optimise it in later courses.) -- ※ 發信站: 批踢踢實業坊(ptt.cc) ◆ From: 118.166.61.86 ※ 編輯: suhorng 來自: 118.166.61.86 (11/09 00:26) ※ 編輯: suhorng 來自: 118.166.61.86 (11/09 00:26)

11/09 00:59, , 1F
強者我同學
11/09 00:59, 1F
文章代碼(AID): #1IVGDn6m (NTU-Exam)