Skip to main content

Section 12.5 Worked Example: Write Arrays - Write a Reversing Algorithm

Subgoals for Evaluating Arrays.

  1. Declaring an array variable
    1. Determine data type to be stored
    2. Determine name
    3. Data type followed by [] followed by name
  2. Instantiating an array object
    1. Determine size (number of elements to be stored)
    2. Assign to variable: keyword new, followed by datatype, followed by [size]. (All values initialized to default value for datatype.)
    3. Assign to variable: {initializer list} where initializer list contains the values to be stored in the array
  3. Accessing array element
    1. Determine value of index for element to be accessed
    2. arrayName[index] returns value stored at that index
    3. index must be between 0 and (arrayName.length-1), inclusive otherwise an IndexOutOfBounds exception occurs at runtime
  4. Changing value of an array element
    1. Determine value of index of element to be changed (remember rules for index values)
    2. Determine the expression for RHS (remember the assignment subgoals for verifying data types)
    3. Write assignment statement to update array element
  5. Traversing an array
    1. Decide if updating, accessing all in forward succession, or accessing some subset of array elements or accessing in a different order
    2. If accessing only, write an enhanced for (for each) loop:
      1. for (DataType varName : collectionName) - traverses collectionName from first element to last element storing a copy of each element from collectionName in varName for each iteration of the loop.
    3. If updating or not accessing all elements in forward succession, write a for loop:
      1. start loop control variable (which will also be index) at 0 to go forwards, (arrayName.length - 1) to go backwards
      2. continuation test is loop control variable < arrayName.length for forwards, loop control variable >= 0 for backwards
      3. update is loop control variable increments for forwards, decrements for backwards
    4. inside loop access / update array element using loop control variable as index into array or varName has value of array element
  6. Whole array actions
    1. Passing an array as an argument
      1. Determine that the an entire array must be passed as an argument to a method by consulting documentation
      2. When calling a method, put variable name that represents the array as an argument in the method call. (Remember that when passing an array as an argument that changes made by the method to the array are persistent.)
    2. Array Assignment
      1. Determine that the reference to an array needs to be changed
      2. The LHS of the assignment is the array reference needing to be changed
      3. The RHS of the assignment is the new array reference

Subsection 12.5.1

You can watch this video or read through the content below it.
Problem: Write the code to “reverse” the elements of an array.
There are several different approaches you might take. We will examine two options here.

Subsection 12.5.2 Solution 1 – copy to new array with reverse traverse

We will begin with a sample array called original, and another array of the same size called copy.
int [] original = {2, 4, 6, 8, 10};
int [] copy = new int [original.length];
Then we loop in reverse for the original array, copying the elements in order and placing them starting at the beginning of the new array. The variable place helps us with traversing the new array in the opposite direction of our reversed traversal of the original.
int place = 0;
for (int i = original.length - 1; i >= 0; i++)
copy[place++] = original[i];

Subsection 12.5.3 Solution 2 – same array with swaps

In this solution, we do not need the whole extra array in memory. The loop only traverses half of the array, swapping the value at i with the value at the mirrored/reflected position array.length - i - 1.
for (int i=0; i<array.length/2; i++)  {
int temp = array[i];
array[i] = array[array.length - i - 1];
array[array.length - i - 1] = temp;
}

Subsection 12.5.4 Practice Pages

You have attempted of activities on this page.