360 likes | 374 Views
This lecture covers the concept of conditionals in computer programming, including how to formulate conditional expressions and design conditional functions. Examples and exercises are provided to reinforce understanding. Text language is English.
E N D
CSC 160Computer Programmingfor Non-MajorsLecture #10: Conditionals I Prof. Adam M. Wittenstein Wittenstein@adelphi.edu http://www.adelphi.edu/~wittensa/csc160/
CW5: part 1 on Booleans • Complete Exercise 4.1.2 from How to Design Programs without using DrScheme. • Feel free to use a calculator - there is one on each of your computers. To get to it the steps are: Start->Programs->Accessories->Calculator.) • What are the results of (> x 3) (and (> 4 x) (> x 3)) (= (* x x) x) for (a) x = 4, (b) x = 2, and (c) x = 7/2 ?
Correction from last class:eq? and equal? • The eq? predefined function always returns false for sentences (a.k.a. strings). • There is another predefined function equal? that works just like eq?, except that it also works on sentences/strings. • For simplicity, we will just also use equal?
Conditions Conditions are most useful in the context of a program. • We call the functions that use them conditional functions. • We formulate them using conditional expressions.
Question 1: Type into Definitions Window ;Variable Definition: (define AGE 10) ;Function Call: (cond [(< AGE 3) ‘toddler] [(and (>= AGE 3) (< AGE 13)) ‘pre-teen] [(and (>= AGE 13) (< AGE 20)) ‘teen] [(>= AGE 20) ‘adult]) ; returns ‘pre-teen Experiment by changing AGE & re-executing
Syntax Rule #4: Conditionals (cond [question … answer] … [question … answer]) Often, the last part is what answer do you want for everything else, in which case, the last question is else. (cond [question … answer] … [else answer])
Question 2: Exercise 4.3.1 Decide which of these expressions is legal: (cond (cond [(< n 10) 20] [(< n 10) 20] [(> n 20) 0] [(and (> n 20) (<= n 30))] [else 1]) [else 1])
Exercise 4.3.1 solution • The expressions are identical except for the third line so look at those. • The second expression does not have an answer on the third line: [(and (> n 20) (<= n 30))] so it is an illegal expression.
Question 3: Why is this illegal? (cond [(< n 10) 20] [ * 10 n] [else 555])
Because… There is no question on the third line.
CW5: part 2 on Conditionals • Complete this simplified version of Exercise 4.3.3 from How to Design Programs without using DrScheme. • Feel free to use a calculator - there is one on each of your computers. To get to it the steps are: Start->Programs->Accessories->Calculator.) • What is the value of:(cond [(<= N 1000) (* .040 1000)] [(<= N 5000) (+ 40 (* (- N 1000) .045))] [else (+ 220 (* (- N 5000) .055))])when n is (a) 500, (b) 2800, and (c) 15000
Question 4: interest-rate A bank pays higher interest rates to depositors with larger balances: • over $10,000, 6% • over $5000 and up to $10,000, 5.5% • over $1000 and up to $5000, 4.5% • up to $1000, 4%
How do we write this in Scheme?Use a conditional (cond [… …] [… …] [… …] [… …])
How do we write this in Scheme?Filling in the questions (cond [(<= amount 1000) …] [(<= amount 5000) …] [(<= amount 10000) …] [( > amount 10000) …])
How do we write this in Scheme?Filling in the answers (cond [(<= amount 1000) .040] [(<= amount 5000) .045] [(<= amount 10000) .055] [( > amount 10000) .060])
Write the program (define (interest-rate amount) (cond [(<= amount 1000) .040] [(<= amount 5000) .045] [(<= amount 10000) .055] [( > amount 10000) .060]))
Strategy for conditionals • Identify number of cases; write cond with that many clauses • If answers are simple, write all the answers & then go back to fill in questions • If questions are simple, write all the questions & then fill in answers
Design Recipe – Version 2 • Figure out precisely what you need to do. 1. Understand the problem 2. Function contract 3. NEW STEP – Data Analysis 4. Write examples (in Scheme notation) • Tell the computer how to do it. 5. Write a skeleton 6. NEW STEP – Choose a template 7. Fill in the function body • Check that the computer does it right. 8. Testing and debugging
“interest-rate” again • Purpose ;To determine the interest rate given an ;amount of money in the bank. • Contract ; interest-rate: number -> number
“interest-rate” again • NEW STEP: Data Analysis ;We take in a number and determine which ;of four intervals it is in. ;We print out a different number for each of ;the intervals.
“interest-rate” again • Examples Borderline Cases ;; (interest-rate 0) -> ?? ;; (interest-rate 1000) -> ?? ;; (interest-rate 5000) -> ?? ;; (interest-rate 10000) -> ?? Interval Cases ;; (interest-rate 500) -> ?? ;; (interest-rate 3000) -> ?? ;; (interest-rate 7000) -> ?? ;; (interest-rate 12000) -> ??
“interest-rate” again • Examples Borderline Cases ;; (interest-rate 0) -> .040 ;; (interest-rate 1000) -> .040 ;; (interest-rate 5000) -> .045 ;; (interest-rate 10000) -> .055 Interval Cases ;; (interest-rate 500) -> .040 ;; (interest-rate 3000) -> .045 ;; (interest-rate 7000) -> .055 ;; (interest-rate 12000) -> .060
“interest-rate” again • Skeleton (define (interest-rate amount) … amount … )
“interest-rate” again • NEW STEP: Template So far we only have one template, for conditionals, so we will use that one. (define (interest-rate amount) (cond [ question answer ] … [ question answer ])
“interest-rate” again • NEW STEP: Template Since we have four cases, we will have four lines of questions and answers, so the template is refined as follows: (define (interest-rate amount) (cond [ question answer ] [ question answer ] [ question answer ] [ question answer ]))
“interest-rate” again • Fill in the Function Body --First fill in the questions. (define (interest-rate amount) (cond [(<= amount 1000) answer] [(<= amount 5000) answer] [(<= amount 10000) answer] [( > amount 10000) answer]))
“interest-rate” again • Fill in the Function Body --Now fill in the answers. (define (interest-rate amount) (cond [(<= amount 1000) .040] [(<= amount 5000) .045] [(<= amount 10000) .055] [( > amount 10000) .060]))
“interest-rate” again • Testing and Debugging --As always, type each of your examples into the interactions window. --If you get an error message or unexpected answer, debug the program to find your mistake.
Question 5: Testing a Program Suppose one of your classmates wrote these examples for interest-rate. Test the program with each of these examples: • (interest-rate 4000) -> .045 • (interest-rate 20000) -> .060 • (interest-rate 6000) -> .040
Question 5: Testing a Program • Which example did not return the expected answer? • Is there a mistake in the program? • What step in the design recipe did he / she make the mistake?
Question 5: Testing a Program • Which example did not return the expected answer? the third one • Is there a mistake in the program? • What step in the design recipe did he / she make the mistake?
Question 5: Testing a Program • Which example did not return the expected answer? the third one • Is there a mistake in the program? no • What step in the design recipe did he / she make the mistake? writing the example
In summary… • Functions like interest-rate need to determine which of several conditions holds for the input. • We call them conditional functions. • A conditional function without numbers. • CW6: Practice with Conditionals. • Using conditional functions to enhance our Animations. Coming up…