100% satisfaction guarantee Immediately available after payment Both online and in PDF No strings attached 4.2 TrustPilot
logo-home
Exam (elaborations)

CPSC110 Pset8 solution

Rating
-
Sold
-
Pages
8
Grade
A
Uploaded on
16-11-2025
Written in
2025/2026

This is the correct and the latest solution for pset 8.

Institution
Course









Whoops! We can’t load your doc right now. Try again or contact support.

Written for

Institution
Study
Course

Document information

Uploaded on
November 16, 2025
Number of pages
8
Written in
2025/2026
Type
Exam (elaborations)
Contains
Questions & answers

Subjects

Content preview

;​; DO NOT PUT ANYTHING PERSONALLY IDENTIFYING BEYOND YOUR CWL IN THIS​
​FILE.​
​;; YOUR CWLs WILL BE SUFFICIENT TO IDENTIFY YOU.​
​;;​
​(require spd/tags)​

​(@assignment psets/pset-08); Do not edit or remove this tag​

;​; These problems will be autograded. NOTE that, for problems 1-5, all of the​
​;; following are required. Violating one or more will cause your solution to​
​;; receive 0 marks.​
​;;​
​;; - Files must not have any errors when the Check Syntax button is pressed.​
​;; Press Check Syntax and Run often, and correct any errors early.​
​;;​
​;; - The function definition MUST call one or more built-in abstract functions.​
​;;​
​;; - For maximum credit the function definition should use the most clear​
​;; and expressive combination of abstract functions. In particular, while​
​;; it is possible to just use foldr for these problems that is not always​
​;; correct. If what is happening is a filter, then it is not correct to​
​;; just implement filtering with foldr.​
​;;​
​;; - The function definition MUST NOT be recursive.​
​;;​
​;; - The function definition MUST NOT use any part of the recursive Natural​
​;; template or the (listof X) template.​
​;;​
​;; - it must not include (cond [(empty? ... anywhere​
​;; - it must not include (cond [(zero? ... anywhere​
​;; - it must not include (if (empty? ... anywhere​
​;; - it must not include (if (zero? ... anywhere​
​;;​
​;; - The result of the function must directly be the result of one of the​
​;; built-in abstract functions. So, for example, the following is not​
​;; a valid function body:​
​;;​
​;; (define (foo x)​
​;; (empty? (filter ...)))​
​;;​
​;; - You MUST NOT change or comment out any check-expects, but you are free​
​;; to add new ones.​

(​ @problem 1)​
​;;​
​;; Design a function called sum-squares that consumes a list of naturals,​
​;; and produces the sum of squaring all of the naturals in the list.​
​;;​

, ;​; For example: (sum-squares (list 5 2 4)) produces 45.​
​;;​
​;; Your function definition must use built-in abstract functions.​
​;; For full marks it must be a composition of exactly 2 built-in​
​;; abstract functions.​
​;;​

(​ @htdf sum-squares)​
​(@signature (listof Natural) -> Natural)​
​;; produce the sum of squaring all of the numbers in lon​
​(check-expect (sum-squares empty) 0)​
​(check-expect (sum-squares (list 5 2 4))​
​(+ (sqr 5) (sqr 2) (sqr 4)))​

​(@template-origin fn-composition use-abstract-fn)​

​(define (sum-squares lon)​
​(foldr + 0 (map sqr lon)))​


(​ @problem 2)​
​;;​
​;; Complete the design of the following function.​
​;;​
​;; Your function definition must use built-in abstract functions.​
​;; For full marks it must be a composition of exactly 2 built-in​
​;; abstract functions.​
​;;​
​;; NOTE: Looking up the function string-contains? in the help desk​
​;; might be helpful...​

(​ @htdf all-a-contain?)​
​(@signature (listof String) String -> Boolean)​
​;; determine if all strings that begin with the letter 'a' contain word w​
​(check-expect (all-a-contain? empty "word") true)​
​(check-expect (all-a-contain? (list "bicycle" "car" "train" "walk")​
​"transportation")​
​true)​
​(check-expect (all-a-contain? (list "assignment") "eight") false)​
​(check-expect (all-a-contain? (list "attend" "radio" "antenna" "listen" "study")​
​"ten")​
​true)​
​(check-expect (all-a-contain? (list "art" "bin" "action" "tin") "in") false)​
​(check-expect (all-a-contain? (list "art" "artery" "ban" "action" "tin")​
​"art")​
​false)​

​(@template-origin fn-composition use-abstract-fn)​
$10.06
Get access to the full document:

100% satisfaction guarantee
Immediately available after payment
Both online and in PDF
No strings attached

Get to know the seller
Seller avatar
06shyun1211

Get to know the seller

Seller avatar
06shyun1211 University of British Columbia
Follow You need to be logged in order to follow users or courses
Sold
New on Stuvia
Member since
3 weeks
Number of followers
0
Documents
8
Last sold
-

0.0

0 reviews

5
0
4
0
3
0
2
0
1
0

Recently viewed by you

Why students choose Stuvia

Created by fellow students, verified by reviews

Quality you can trust: written by students who passed their tests and reviewed by others who've used these notes.

Didn't get what you expected? Choose another document

No worries! You can instantly pick a different document that better fits what you're looking for.

Pay as you like, start learning right away

No subscription, no commitments. Pay the way you're used to via credit card and download your PDF document instantly.

Student with book image

“Bought, downloaded, and aced it. It really can be that simple.”

Alisha Student

Frequently asked questions