Skip to main content
Contents
Dark Mode Prev Up Next Scratch ActiveCode Profile
\(
\newcommand{\lt}{<}
\newcommand{\gt}{>}
\newcommand{\amp}{&}
\definecolor{fillinmathshade}{gray}{0.9}
\newcommand{\fillinmath}[1]{\mathchoice{\colorbox{fillinmathshade}{$\displaystyle \phantom{\,#1\,}$}}{\colorbox{fillinmathshade}{$\textstyle \phantom{\,#1\,}$}}{\colorbox{fillinmathshade}{$\scriptstyle \phantom{\,#1\,}$}}{\colorbox{fillinmathshade}{$\scriptscriptstyle\phantom{\,#1\,}$}}}
\)
Section 14.4 Writing-ArrayLists-WE2-P1
Subgoals for Writing ArrayLists.
Importing the ArrayList class
Before using ArrayList, import it from the java.util package:
import java.util.ArrayList;
Declaring an ArrayList variable
Determine the type of objects to be stored (use wrapper classes for primitives, e.g., Integer instead of int)
Determine the name of the ArrayList variable
Use syntax:
ArrayList<DataType> name;
Instantiating an ArrayList object
Use the
new
keyword with the constructor to create a new ArrayList object (When ArrayLists are instantiated, they are empty and have a size of 0.)
Adding elements to an ArrayList
To add to the end of an ArrayList, use:
listName.add(valueToBeAdded)
To add an element at a specific location in an ArrayList, use:
listName.add(index, valueToBeAdded)
where index is within the bounds 0 to
listName.size()
Accessing an element in an ArrayList
Determine the index of the element to be accessed
Use:
listName.get(index)
to retrieve the element
Ensure the index is within bounds: 0 to
listName.size() - 1
, otherwise an IndexOutOfBoundsException occurs
Changing a value in an ArrayList
Determine the index of the element to be changed
Determine the new value or expression to assign
Use:
listName.set(index, newValue)
to update the value
Ensure the index is within bounds: 0 to
listName.size() - 1
, otherwise an IndexOutOfBoundsException occurs
Decide whether accessing all elements, updating, or accessing a subset
If only
accessing elements, use an enhanced for (for-each) loop:
for (DataType item : listName)
- iterates from first to last, storing a copy of each element in
item
If updating or using indices, use a traditional for loop:
Initialize loop control variable to 0 (or
listName.size() - 1
for reverse)
Set condition:
i < listName.size()
(or
i >= 0
for reverse)
Increment or decrement loop control variable appropriately
Use Subgoals 5 or 6 to access or change values as appropriate
Passing an ArrayList as an argument
Check if the method expects an ArrayList argument (check documentation or method signature)
When calling a method, pass a reference to an ArrayList (usually variable name) as an argument in the method call.
Note: changes to elements in the ArrayList that are done inside the method will persist
Subsection 14.4.1
Exercises Exercises
1.
Q4: What are the contents of
alpha
after this code has been executed?
import java.util.ArrayList;
ArrayList<Integer> alpha = new ArrayList<>();
Collections.addAll(alpha, 10, 20, 30, 40, 50, 60, 70);
int start = alpha.get(alpha.size() - 1);
for (int i = 1; i < alpha.size(); i++) {
alpha.set(i, alpha.get(i - 1));
}
alpha.set(0, start);
{20, 30, 40, 50, 60, 70, 10}
Incorrect
{10, 20, 30, 40, 50, 60, 70}
Incorrect
{10, 10, 20, 30, 40, 50, 60}
Incorrect
{70, 10, 10, 10, 10, 10, 10}
Correct
{10, 10, 10, 10, 10, 10, 10}
Incorrect
2.
Q5: What are the contents of
beta
after this code has been executed?
import java.util.ArrayList;
ArrayList<Integer> beta = new ArrayList<>();
Collections.addAll(beta, 10, 20, 30, 40, 50, 60, 70);
for (int i = 1; i < beta.size(); i++) {
beta.set(i, beta.get(i - 1));
}
{20, 30, 40, 50, 60, 70, 10}
Incorrect
{10, 20, 30, 40, 50, 60, 70}
Incorrect
{10, 10, 20, 30, 40, 50, 60}
Incorrect
{70, 10, 20, 30, 40, 50, 60}
Incorrect
{10, 10, 10, 10, 10, 10, 10}
Correct
3.
Q6: What happens when this code is executed on
gamma
?
import java.util.ArrayList;
ArrayList<Integer> gamma = new ArrayList<>();
Collections.addAll(gamma, 10, 20, 30, 40, 50, 60, 70);
for (int i = 0; i < gamma.size(); i++) {
gamma.set(i, gamma.get(i + 1));
}
{20, 30, 40, 50, 60, 70, 70}
Incorrect
{20, 30, 40, 50, 60, 70, 10}
Incorrect
{10, 20, 30, 40, 50, 60, 70}
Incorrect
{10, 10, 20, 30, 40, 50, 60}
Incorrect
IndexOutOfBounds Exception
Correct
4.
Q7: Put the following code in order so that the values inserted into the ArrayList are stored in increasing order.
import java.util.ArrayList;
import java.util.Scanner;
---
ArrayList<Integer> increasing = new ArrayList<Integer>();
---
System.out.println("Enter values to be inserted, -1000 to end");
---
Scanner scan = new Scanner(System.in);
---
int value = scan.nextInt();
---
while (value != -1000) {
---
int insertAtIndex = 0;
---
while(insertAtIndex < increasing.size() && increasing.get(insertAtIndex) < value) {
---
insertAtIndex++;
}
---
increasing.add(insertAtIndex, value);
---
System.out.println("Enter values to be inserted, -1000 to end");
---
value = scan.nextInt();
---
}
You have attempted
of
activities on this page.