Just like we did with integers, we can declare variables
and assign values to them:
data:image/s3,"s3://crabby-images/b704d/b704d3ac24d48ef631f374dc9664774828350c29" alt=""
Another example:
data:image/s3,"s3://crabby-images/fbd28/fbd289568db0c5d8e49d195a09c6fcf05b35b322" alt=""
Again, as with integers, the standard operators apply:
data:image/s3,"s3://crabby-images/a0c4e/a0c4e9a57203cfb843aeba30fc2cdc30e15b20a7" alt=""
In-Class Exercise 1:
Write a program to print out the area of a circle
whose radius is 1.5 inches.
In-Class Exercise 2:
Can you find a well-known formula or law in science or engineering
that uses all four of the standard operators:
+, -, *, /? If not, find one that uses as many
as possible.
In-Class Exercise 3:
Do the increment and decrement operators work with
real numbers?
Now consider this simple example:
data:image/s3,"s3://crabby-images/ccba4/ccba40b972c67a2581630cbb598dcf28eb785e66" alt=""
In-Class Exercise 4:
Change the assignment to:
data:image/s3,"s3://crabby-images/ddeb6/ddeb633cc706ec9b2d601a4cc8e24c69ba763055" alt=""
and see what prints. Explain the result.
Real-valued variables in loops
Let's write a program to sum the numbers
0.1, 0.2, ..., 1.0.
Here's one way:
data:image/s3,"s3://crabby-images/bf880/bf8801764255e566e9579f19a7707b2f7a3ced06" alt=""
In-Class Exercise 5:
Use a table to trace the execution of the above loop.
Show the changing values of sum, x, and i.
We'll now examine a number of variations:
- We can use real variables directly in the for-loop:
data:image/s3,"s3://crabby-images/5fa7b/5fa7bf981861797a46ad244610819b599eedd14e" alt=""
- Here's the same example with shortcut operators:
data:image/s3,"s3://crabby-images/a0163/a01638ffe974457075533491de7d0ca65974bbe8" alt=""
Next, consider this product computation:
data:image/s3,"s3://crabby-images/056c0/056c003a250cde6277e5da1723f0a53990f81127" alt=""
In-Class Exercise 6:
Do you recognize what the above loop is computing?
Edit, compile and execute to see the output.
In-Class Exercise 7:
Modify the above program to compute the product
of numbers 0.1 * 0.2 * ... * 1.0.
What do you observe as the output that is
inconsistent with the product in the previous
exercise? What is the explanation?
An example with a nested loop
Let's write a program to explore the
sum 1 + (1/2) + (1/2)2 + ... + (1/2)n.
Let's do this in steps:
- First, some pseudocode at the highest level:
sum = 0
for k=0 to n {
x = (1/2) raised-to-power k
sum = sum + x
}
Print sum
- But (1/2)k = (1/2) * (1/2) * ... * (1/2) (k-times).
=> This is itself a loop.
- Let's first write the inner loop for fixed k:
data:image/s3,"s3://crabby-images/e4119/e411992a626147c955816be844c861257e78c864" alt=""
In-Class Exercise 8:
Try this out to see that it works.
- We'll now put this into the larger loop for the sum.
data:image/s3,"s3://crabby-images/3be21/3be21f3d0867c33b3fcd5881b790e35bf6e3763a" alt=""
In-Class Exercise 9:
Trace the execution using a table, with changing values
of sum, k, power and i.
In-Class Exercise 10:
Does this program work for the corner cases of
n=0 and n=1?
In-Class Exercise 11:
Explore what you get for larger values of n.
Can you write the sum mathematically and determine
the limiting value (as n→∞)?
Casting
Consider the following program:
data:image/s3,"s3://crabby-images/90ae0/90ae0034544b2d0143f4bb0624ab9c17707d2e65" alt=""
In-Class Exercise 12:
What you suppose will be printed? Try it.
Then, change the program so that you initially
assign the value of 1 to i and
then assign i to x.
An assignment from an int to a
double works fine:
data:image/s3,"s3://crabby-images/6cd7e/6cd7e5cf31984ece1d0b356c8e564cf14b2fc592" alt=""
About casting:
- The assignment from int to double
works because every int is a valid double value.
- However, a double need not be a valid int.
=> Which is why the compiler complains.
- However, we can force an assignment using an
explicit cast (jargon alert!)
data:image/s3,"s3://crabby-images/0c0d1/0c0d1ce523e3ca3ba6139df5d8a8c2d865a6887a" alt=""
- The result: the largest integer less than the real.
=> The result is 1 above.
- An explicit cast is need even if the double's
value happens to be an integer like 1.0.
- As we'll see later, casting is a general operation
that can be applied to different variable types.
In-Class Exercise 13:
What do you get when you cast the real value
0.5 to an int?
Reading and writing
Consider this somewhat complex program:
data:image/s3,"s3://crabby-images/2f384/2f384e9c17d38a9d4c35ab48074fa797168c8be7" alt=""
We'll read this program in steps:
When writing nested for-loops:
- Write the first line of outermost loop and the closing brace:
data:image/s3,"s3://crabby-images/191fa/191fa57f50faa693f3fc36de24f23a89b20d5b5f" alt=""
- Then, back up into the body and write the code inside:
data:image/s3,"s3://crabby-images/2aebe/2aebe568857e14f958bd86f9de7fab445245b321" alt=""
- ... and so on.
In-Class Exercise 14:
Armed with your improved reading skills and added
knowledge of syntax, go back to Module 0 and read
through the first primes program. Examine the
for-loops in particular - you should be able to
trace through them.
When things go wrong
In-Class Exercise 15:
What is the bug in this program written
to compute the sum of numbers 0.01, 0.02, ..., 0.1?
data:image/s3,"s3://crabby-images/6d494/6d494957bc01a28411268ea5eac795493dde93eb" alt=""
In-Class Exercise 16:
What about this one? (We've shown only the code
inside main.)
data:image/s3,"s3://crabby-images/a1e9a/a1e9a2c1557daf778617c41907dd510783f442a5" alt=""
In-Class Exercise 17:
What is the bug in this program written
to compute the product of numbers 1, 2, ..., 10?
data:image/s3,"s3://crabby-images/34294/3429409e688188a840700c285045bae41e19765d" alt=""