Logo

Hello! wget this notebook RIGHT NOW

(Find the link in ‘coding’ on SLACK)

Topic 6.1 - Array Creation and Access (Sreeja)

Vocabulary

Declaring an Array

Defines the array variable, specifying its data type and name.

// Syntax: dataType[] arrayName;
int[] numbers; // Declare an integer array
String[] names; // Declare a string array

Creating an Array

Gives memory for the array and specifies its size.

// Syntax: arrayName = new dataType[size];
numbers = new int[5]; // Create an integer array with 5 elements
names = new String[3]; // Create a string array with 3 elements

Initializing an Array

Populates the array with initial values.

// Syntax: arrayName = new dataType[size];
numbers = new int[5]; // Create an integer array with 5 elements
names = new String[3]; // Create a string array with 3 elements

Accessing Array Elements

Retrieves a specific element’s value from the array using its index.

int[] numbers = {10, 20, 30, 40, 50};
int element = numbers[2]; // Access the third element (30) using index 2
System.out.println(element); // Output: 30

30

Array Length

Obtains and displays the number of elements in the array.

int[] numbers = {10, 20, 30, 40, 50};
int length = numbers.length; // Get the length of the array
System.out.println("Array length: " + length); // Output: Array length: 5
Array length: 5

Modifying Array Elements

Updates the value of a specific element in the array.

int[] numbers = {10, 20, 30, 40, 50};
numbers[2] = 35; // Change the third element to 35
35

Iterating Through an Array

Loops through the array, printing each element.

int[] numbers = {10, 20, 30, 40, 50};
for (int i = 0; i < numbers.length; i++) {
    System.out.println(numbers[i]);
}
10
20
30
40
50

Enhanced For Loop (For-each)

Iterates through the array using a simplified loop structure, printing each element.

int[] numbers = {10, 20, 30, 40, 50};
for (int number : numbers) {
    System.out.println(number);
}
10
20
30
40
50

Topic 6.2 - Traversing Array (1D) (Tanisha)

Using iteration statements (standard for loops and while loops) to access each element in an array.

Standard For Loop

Review on For Loops

image

import java.util.Random;

public class RandomArray {
    public static void main(String[] args){
        int [] list = new int[6];
        Random rand = new Random(); 

    for (int i = 0; i < list.length; i++){
        list[i] = rand.nextInt(4);
    }

    // FOR LOOP 2
   for(int element: list){
        System.out.println(element);
    }
 }

}

RandomArray.main(null);
3
0
0
2
1
0

Class Discussion-Take Notes, these will count for points in your hacks!

  1. What do the for loops accomplish?

The loop generates random numbers and puts it into a list with length 6.

  1. What is the difference between how elements of the array list are accessed?

The elements in the 1st loop are accessed using in a normal loop. The 2nd loop uses an enhanced loop.

  1. BONUS: When the array list of ints was first created, what was each int in the list initialized to?

0

download

For loop : Accessing Some Elements of a List

Class Discussion-Take Notes, these will count for points in your hacks!

  1. If I only wanted to access the elements at even indices of the list (0, 2, 4), what could I change in the statement below to accomplish that?

I would change it to i++ to i+=2

  1. What about odd?

I would change int i=0 to int i=2 and use i+=2.

// EVEN
int[] list = {0, 1, 2, 3, 4, 5};
System.out.println("Even Index");
for(int index = 0; index < list.length; index+=2){
    System.out.println(list[index]);
}

// ODD
int[] list = {0, 1, 2, 3, 4, 5};
System.out.println("Odd Index");
for(int index = 1; index < list.length; index+=2){
    System.out.println(list[index]);
}
Even Index
0
2
4
Odd Index
1
3
5

Note: These are NOT traversals, even though these are for loops. This is because not every element in the array is accessed.

Standard While Loop

  1. Does the following loop accomplish traversing the array? yes
int [] list = new int[5];
int index = 0; 

while (index < list.length) 
{
    // Do something
    index ++; 
}
  1. This while loop and the for loop we used earlier accomplish the same task. The main difference is that after the loop is completed, the variable ‘index’ in the while loop will still exist. The variable ‘i’ in the for loop will not. Why?

It is not a in scope variable because i is a temporary variable.

Bounds Errors

When traversing an array, we need to be careful with the indices to avoid an ArrayIndexOutOfBoundsException being thrown.

ATTENTION: MOST COMMON MISTAKE:

  1. What is wrong with the for loop and while loop below? Why does this produce an ArrayIndexOutOfBoundsException error?

The index is one more than the length of the list. ArrayIndexOutOfBoundsException is produced because no index exists at that length.

for(int i = 0; i <= list.length; i ++)
int index = 0; 
while (index <= list.length)

Off by One Error : missing the first or last element of an array when trying to traverse

[0, 1, 2, 3, 4]
// This won't access the last element in the list
for(int i = 0; i < list.length - 1; i ++)
// This won't access the first element in the list
int index = 1; 
while (index <= list.length)

Developing Methods Using Arrays

Reviewing common methods asked on AP Exam FRQs

Average Value

Complete the popcorn hack below in order to return the average value of the elements in the list numbers.

public class ArrayAverage {
    public static void main(String[] args) {
        int[] numbers = {5, 10, 15, 20, 25};
        int sum = 0;
        double average;
        
        for (int i = 0; i < numbers.length; i ++) {
            sum += numbers[i]; 
        }
       
        average = (double) sum / numbers.length; /* missing code */
        
        System.out.println("The average of the numbers is: " + average);
    }
}

ArrayAverage.main(null);
The average of the numbers is: 15.0

6.3 Enhanced for loop for Arrays (Vivian)

//syntax for enhanced for loop
for (dataType element : array) {
    // code to process 'element'
}
//array of int matches element int
int[] numbers = {1, 2, 3, 4, 5};
for (int num : numbers) {
    System.out.println(num);
}
1
2
3
4
5

Comparing a regular for loop with the enhanced for loop

Popcorn Hack: Rewrite this code to use an enhanced for loop instead. make comments explaining what you added/changed

import java.util.List;

class Quote {
    private List<String> quotes;
    private List<String> emotions;

    public Quote(List<String> quotes, List<String> emotions) {
        this.quotes = quotes;
        this.emotions = emotions;
    }

    public void printQuotesWithEmotions() {
        // Make a change in the code here! 
        int g = 0;
        for (String quote :  quotes) {
            System.out.println("Quote: \"" + g + "\"");
            System.out.println("Emotion: " + emotions.get(g)); // You cannot do an enhanced for loop with two variables of different sets. That does not work, as the for loop cannot increment both at the same time. Therefore, we have to use a hybrid or a regular loop. I have used a hybrid one here. 
            System.out.println("---------------------------");
            g++;
        }
    }

    public static void main(String[] args) {
        List<String> quotes = List.of(
            "Success is not final, failure is not fatal: It is the courage to continue that counts.",
            "The only way to do great work is to love what you do.",
            "The best way to predict the future is to create it."
        );

        List<String> emotions = List.of(
            "Courageous",
            "Passionate",
            "Innovative"
        );

        Quote quotePrinter = new Quote(quotes, emotions);
        quotePrinter.printQuotesWithEmotions();
    }
}

Quote.main(null);
Quote: "0"
Emotion: Courageous
---------------------------
Quote: "1"
Emotion: Passionate
---------------------------
Quote: "2"
Emotion: Innovative
---------------------------

What are some of the benefits of using an enhanced for loop in this case versus a regular for loop?

The enhanced for loop is simple and makes sure no index out of bound errors occur. We also don’t need the specific index for the string, so we can use an enhanced for loop.

Limitations to enhanced for loop

For the next two code blocks, decide whether or not its better to use a regular for loop or an enhanced one, explain why. write the code for them

  1. Searching for an Element in an ArrayList

Enhanced because you don’t need to index

ArrayList<String> names = new ArrayList<>();
String searchName = "Vivian";

//code goes here
for (ArrayList<String> name: names) {
}
  1. Removing Even Numbers from an ArrayList

Normal because you need an index

ArrayList<Integer> numbers = new ArrayList<>();

//code goes here
for () {
}

6.4: Developing Algorithms Using Arrays (Isabelle)

How to identify the maximum or minimum value in an array

It is a common task to determine what the largest or smallest value stored is inside an array. In order to do this, we need a method that can take a parameter of an array of primitve values (int or double) and return the item that is at the appropriate extreme.

Inside the method a local variable is needed to store the current max or min value that will be compared against all the values in the array. You can assign the current value to be either the opposite extreme or the first item you would be looking at.

You can use either a standard for loop or an enhanced for loop to determine the max or min. Assign the temporary variable a starting value based on what extreme you are searching for.

Inside the for loop, compare the current value against the local variable; if the current value is better, assign it to the temporary variable. When the loop is over, the local variable will contain the appropriate value and is still available and within scope and can be returned from the method.

Find max in an array of double values

private double findMax(double [] values) {
    double max = values[0];

    for (int index = 1; index < values.length; index++) {
        if (values[index] > max) {
            max = values[index];
        }
    }
    return max;
}

Find min in an array of int values

private int findMin(int [] values) {
    int min = Integer.MAX_VALUE;

    for (int currentValue: values) {
        if (currentValue < min) {
            min = currentValue;
        }
    }
    return min;
}

Let’s Practice!

Popcorn hack #1

// What needs to be changed to find the index of the max value? (write correct code in cell below)
private int findMax(double [] values) {
    double max = values[0];
    int maxIndex = 0;

    for (int index = 1; index < values.length; index++) {
        if (values[index] > max) {
            max = values[index];
            maxIndex = index;
        }
    }
    return (int)max;
}

How to calculate the average value from objects in an array

It is a common task to determine what is the average value returned from items stored inside an array. In order to do this, we need a method that can take a parameter of an array of Objects (DebugDuck) and calculate and return the average value that each instance of DebugDuck returns from the method.

Inside the method; a local double variable is needed to store the accumulated values. Then we use a for loop to traverse the array and add the current total to the variable. After accumulating all the values we need to divide the total by the number of items stored in the array.

Using a standard for loop

private double calculateAverage(DebugDuck [] ducks) {
    double average = 0.0;

    for (int index = 0; index < ducks.length; index++) {
        average += ducks[index].getQuestionCount();
    }
    average = average / ducks.length;

    return average;
}

Using a standard enhanced loop

private double calculateAverage(DebugDuck [] ducks) {
    double average = 0.0;

    for (DebugDuck currentDuck: ducks) {
        average += currentDuck.getQuestionCount();
    }
    average = average / ducks.length;

    return average;
}

Does the order of accumulation matter?

Nopeeeeeee, you can go forward and backward

Can you declare the variable inside the loop?

Nope, because it will reset the variable

Shfiting Array contents to the right

The contents of an array often need to be shifted as part of a solution to using the data inside.

We need to know how much to shift the array by. This will need to be an int obviously.

In order to move the contents we next need to make an empty array of the same size and then iterate over the original array and properly copy the values to the adjusted index in the new array.

We then need to assign the new array back into the original variable.

What kind of for loop should we use? Why?

Normal because YOU NEED THE INDEX

int [] numbers = {1,2,3,4,5};
int [] shifted = new int [numbers.length];
int shift = 8;
for (int index = 0; index < numbers.length; index++) {
    shifted [Math.abs((index + shift) % numbers.length)] = numbers[index];
}
numbers = shifted;
for (int num : numbers) {
    System.out.println(num + " ");
}
3 
4 
5 
1 
2 

Why are we using the % operator?

It gets the remainder and prevents an index out of bounds.

Popcorn hack #2

How would we code a left shift? Write a left shift using the variables below

String[] words = {"alpha", "beta", "gamma", "delta"};
int shiftWord = 2;

String[] shiftedWords = new String[words.length];

for (int i = 0; i < words.length; i++) {
    int newIndex = (i + shiftWord) % words.length;
    shiftedWords[i] = words[newIndex];
}

for (int i = 0; i < shiftedWords.length; i++) {
    System.out.println(shiftedWords[i]);
}
gamma
delta
alpha
beta

Why should the array index be wrapped in a call to Math.abs?

It is because we cannot have negative indexes

Hacks

Scoring Guidelines:

6.1 HACK 1 FRQ (<5 min)

Follow the steps in the lesson to just make an array that has some relation to your project. Feel free to use the code examples we provided in your hack if you would like.

public class Main {
    public static void main(String[] args) {
        // Create a 2D array to store stock data (symbol, name, price)
        String[][] stocks = new String[5][3]; // You can change the size as needed

        // Initialize the stock data
        stocks[0] = new String[] {"AAPL", "Apple Inc.", "150.25"};
        stocks[1] = new String[] {"GOOGL", "Alphabet Inc.", "2700.50"};
        stocks[2] = new String[] {"MSFT", "Microsoft Corporation", "305.75"};
        stocks[3] = new String[] {"AMZN", "Amazon.com Inc.", "3350.20"};
        stocks[4] = new String[] {"TSLA", "Tesla Inc.", "750.10"};

        // Access and display stock information
        for (String[] stock : stocks) {
            System.out.println("Symbol: " + stock[0]);
            System.out.println("Name: " + stock[1]);
            System.out.println("Price: " + stock[2]);
            System.out.println();
        }
    }
}

Main.main(null)
Symbol: AAPL
Name: Apple Inc.
Price: 150.25

Symbol: GOOGL
Name: Alphabet Inc.
Price: 2700.50

Symbol: MSFT
Name: Microsoft Corporation
Price: 305.75

Symbol: AMZN
Name: Amazon.com Inc.
Price: 3350.20

Symbol: TSLA
Name: Tesla Inc.
Price: 750.10

6.2 HACK 1 FRQ (<10 min)

Prime Numbers in an Array (5-10 min)

Create a loop to identify and print the prime numbers from an array of integers. Your loop MUST traverse through the given list. Some things to consider:

BONUS: Do this with a for loop AND a while loop

public class PrimeNumbers {
    public static boolean isPrime(int num) {
        if (num <= 1) {
            return false;
        }
        
        for (int i = 2; i <= Math.sqrt(num); i++) {
            if (num % i == 0) {
                return false;
            }
        }
        
        return true;
    }
    public static void main(String[] args) {
        int[] numbers = {1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20};

        System.out.println("Prime numbers in the array:");
        
        for (int number : numbers) {
            if (isPrime(number)) {
                System.out.println(number);
            }
        }
    }
}
PrimeNumbers.main(null)
Prime numbers in the array:
2
3
5
7
11
13
17
19

6.2 HACK 2 MCQ (<5 min)

Multiple Choice Questions

Do NOT Run the code cells. Try to do this on your own.

  1. What will be displayed as the output?
String [] list = {"red", "yellow", "blue"}; 
for (int i = 0; i < list.length; i++)
{
    System.out.print(list[i].length()+ "-" );
}

Write why you chose that answer!

C; because it gets the length of each of the items in the list, prints it, and adds a dash to the end

  1. The code below is meant to display every other number in the list numbers. Which of the following should replace the missing code in order to do this?
int [] numbers = {3, -4, 6, -7, 2}; 
for(/*missing code*/)
{
    System.out.println(numbers[i]);
}

Write why you chose that answer!

E; we initialize i to be 0 so that the loop starts at the first item of the list, then we add two to the index to get every other number until i is out of bounds or greater than the length of numbers

  1. (This one is a little hard) Which of the following would fix the code so that the elements in arr are reversed. Hint: try creating a list in your head and trace the code to see if the code accomplishes its goal.
public static void reverseArray(double [] arr)
{
    for(int = 0; i< arr.length; i++)
    {
        double temp = arr[i];
        arr[i] = arr[arr.length-1-i];
        arr[arr.length-1-i] = temp; 
    }
}

In case you are having trouble with question 3 the answer is B. Write about why!

Only the second one has the correct amount of iterations

6.3 HACK

6.4 HACK