Lecture Notes 13: More about 1-D Arrays
Objectives
- Construct programs that manipulate arrays using loops
- Identify the key mechanisms to traverse and manipulate arrays without loss of data
- Distinguish the ways in which to traverse/access arrays using loops
- Demonstrate how to trace through an array manipulation using a table
- Identify and correct errors and bugs in the design of 1-D array exercises
Before Starting
- Read Sections 13.01 to 13.03 in the Codio Course
If you do not have your Codio course ready, use any text editor or simple IDE. Some possibilities are:
- Write using Sublime; Compile and run in the Terminal
- Use IDEs like: IntelliJ, DrJava, or JGrasp
Catching Up
Before we move forward, let's catch up (complete any remaining work from the previous module)
In this case, make sure we've got:
- One-Dimensional Arrays... Declaring, Initializing, and Accessing!
More examples
Example 1: let's write a program to "rotate" an array:
data:image/s3,"s3://crabby-images/8b2d0/8b2d02493ce87fc31babd96d3ddbbfc87466d1bf" alt=""
- Thus, we want to shift each element into the next position rightwards.
- The last element gets into the first position.
- First, we'll use the help of an additional array to
make this happen:
data:image/s3,"s3://crabby-images/f4fdd/f4fdd2b85b41f662b168566f9add34be2c4e7154" alt=""
- We first copied elements A[0],...,A[n-2] into
locations ("boxes") B[1], ..., B[n-1].
- Then, we copied A[n-1] into B[0].
- The array B is in the desired form.
- Lastly, we copied all of B into A
so that A has the desired rotation.
Activity 1:
Trace each array in each step, showing the contents. Use a table!! (columns should focus on important variables, like iterators, array contents, and indices)
- It is possible to do without an additional array:
data:image/s3,"s3://crabby-images/cd980/cd9804c4b3a499b6b25ea27b2b65009d1307a38a" alt=""
Activity 2:
Trace through the above example (
RotateExample2.java)
by hand to see how it works. Then, also trace through
the version below and explain why it does not work:
data:image/s3,"s3://crabby-images/c7ced/c7cedfd9e4addd857b3af1fe8939e29627b65615" alt=""
Reversing!
Next, in the second example, we'll write code to reverse an array:
data:image/s3,"s3://crabby-images/372a1/372a1102dd39807b6f4499df5c25bc80f1243d5b" alt=""
Here's a version that uses an additional
array:
data:image/s3,"s3://crabby-images/3622d/3622dae1592e5aabd18210bb4e59e54469e3e4d4" alt=""
Activity 3:
Trace through the program above by hand!! (use a table!).
Activity 4:
Write code in
MyReverseExample.java
to achieve reversal
in the same array A,
without using an extra array like
B.
Adding!
Example 3: adding two arrays
data:image/s3,"s3://crabby-images/b76d1/b76d1ba3b3e12da0fa7f97b84a31863343b219ca" alt=""
- Here, we have added two arrays element-by-element.
- The resulting values are put into a third array
(C).
Activity 5:
Trace through the program above (use a table!).
Activity 6:
Write a different version
(in
AdditionExample2.java) that
takes an array
A and computes
the following sum of two arrays, element by element, as in the
above example.
However, in this case, you are to compute the sum (element-by-element)
of the array
A and its reversal,
putting the
result into array
B.
Do this without using a third array.
Activity 7:
Trace through the program below by hand.
data:image/s3,"s3://crabby-images/00a2a/00a2a593f89fa5972e8dc5b3a75084864514f9af" alt=""
What does it print?
Activity 8:
Trace through the program below by hand.
data:image/s3,"s3://crabby-images/b7765/b7765d299392a160c7358641868d805c6e427d98" alt=""
What does it print?
Activity 9:
Trace through the program below by hand.
data:image/s3,"s3://crabby-images/683d9/683d92d92d02f80438c8caa8aae0b00ae31dcfff" alt=""
What does it print?
Look up the definition of
factorial somewhere and relate that to
the computation above.
Note: in the exercise above, we learned a few new
things about using arrays:
- Sometimes, we create one additional slot so that
we can use the index A[n] when convenient.
- A for-loop can have other variables that change
with the loop besides the loop variable.
Reading and writing
Let's look at an example and how to read the code:
data:image/s3,"s3://crabby-images/7525d/7525d203463669de5fbfc4ad696bb83d250b90d1" alt=""
- First, look for the array declaration and identify the
type (e.g, int or double etc):
data:image/s3,"s3://crabby-images/8c75b/8c75be4b5bbea7e4c58263ed2f8bd1677f23d74f" alt=""
- Say to yourself, "A is an array that holds
double's".
- "B is an array that holds
int's".
- Then, look to see how much space is created:
data:image/s3,"s3://crabby-images/5b29e/5b29e0f85260a61597794ff711e952a50aae5755" alt=""
- Say to yourself, "A's size is 5, created
using the new operator".
- "A's elements are all initially 0".
- "B's size is 5, directly initialized to
particular values".
- Now, check that, when variables are used to access
array components (slots), the bounds are right:
data:image/s3,"s3://crabby-images/d4c7a/d4c7ac49f6ce4afdc330588bd4629e4f477241ca" alt=""
Writing:
- Writing the declaration:
data:image/s3,"s3://crabby-images/1306c/1306c039a40de66c64cb81c040da02d6c6ee1154" alt=""
- No spaces between either the type (double),
nor between the brackets.
- A single space between the right bracket the array variable
name.
- Creating space:
data:image/s3,"s3://crabby-images/180a8/180a890165a0bb99da2c727194aa9933c0bfdf66" alt=""
- A space on either side of the assignment operator, =.
- A space on either side of the new reserved word.
- The space after the double is optional. (Here, we have
a space.)
- No spaces for the size and brackets.
- Prefer the use of the new operator except
for small-ish arrays whose initial contents are known and fixed.
data:image/s3,"s3://crabby-images/15967/159676b2763c73b0c3f03e58fa8983beb84ae95b" alt=""
- No spaces when using the values in an array:
data:image/s3,"s3://crabby-images/08764/08764a2dec624f01daf3089ca44dd99b56be5d41" alt=""
Using the array's built-in length. Consider this variation:
data:image/s3,"s3://crabby-images/64066/64066f78bd26751fbde4ff3075b70a7f319c3b8e" alt=""
- We could either n or the array's length A.length.
- So, which one should we use?
- Generally, when the limit is a mathematically meaningful
variable like n above, you can use n.
- Otherwise, use the array's length.
- Sometimes, using an array's length variable can make
a program needlessly verbose.
- For example, here's the array-reversal example using
the length variable:
data:image/s3,"s3://crabby-images/c40f2/c40f2ab6b42757b92c51ca4b0df4312c59b18d34" alt=""
Variable names:
- Here is the first length example, re-written with
different variable names:
data:image/s3,"s3://crabby-images/ec7d8/ec7d89f45dde7554ca481a8f884eb1aaaf55a327" alt=""
- For a program this short, it is probably a bit verbose.
- Notice: we used different names for the loop variables
in the two for-loops.
When things go wrong
Which of the following have errors (syntax or bugs)
and what are they? Can you tell just by reading?
Don't pay attention to the purpose - just whether
the program will compile or run.
Activity 10:
data:image/s3,"s3://crabby-images/5f20c/5f20cff856caa9701dcd9585b146bb09c53362fc" alt=""
Activity 11:
data:image/s3,"s3://crabby-images/b0a83/b0a83463dc6b8bc081c076d5641054808fb7bf50" alt=""
Activity 12:
data:image/s3,"s3://crabby-images/ed343/ed343c0639c88eda69e6887f7c5c66590b39a839" alt=""
Activity 13:
The following program has multiple errors. See if you
can spot them by reading. Then in
ErrorExample4.java
fix the errors by editing the program. The array
A
needs to be an array of
double's.
data:image/s3,"s3://crabby-images/976dd/976ddc3c7813c8091a0caa61019c0d1f7fa3ea84" alt=""