website/content/ta/fall2017/cpsc220/oct2.md
2020-01-15 21:51:49 -05:00

3.1 KiB

Lecture Notes Oct 2nd

Array

array is not a reserved word, it's a concept. Arrays are able to hold multiple values under one name of the same type.

For instance, you can have an array of integers.

Properties of an array

  • Size (n)
  • index [0, n - 1]

You can declare arrays by saying the type '[]' and the name of the array

int[] numbers;
double[] gpas;
float[] grades;

Before you can use the array, you must new it

numbers = new int[10];

Where 10 is the size of the array.

You can combine both the declaration and initialization

double[] points = new double[7];

You can access individual elements of the array by using its index. Indexes start from zero

points[0] = 5.4; // The first element in the point array is 5.4

The .length property of an array gives the size of the array

For-Loops + Arrays

You can print out each element in the array using a for loop

for (int i = 0; i < numbers.length; i++) {
    System.out.println(numbers[i]);
}

You can ask a user to input a value to each element in the array

for (int i = 0; i < points.length; i++) {
    System.out.print("Enter a number: ");
    points[i] = scnr.nextInt();
}

While-Loops + Arrays

You can use a while loop to search the array

int i = 0;
int number = 5;
// While the index is within the array size and the number isn't found
while (i != number.length && number != numbers[i]) {
    i++
}
if (i == numbers.length) {
    System.out.println(number + " was not found.")
} else {
    System.out.println(number + " was found at index " + i)
}

If you don't include the i != number.length you will obtain an IndexOutOfBounds error.

The example above is called a Linear Search.

Linear searches work on an unsorted and sorted arrays.

Methods + Arrays

You can pass an array into a method

public static void exampleMethod(int[] sample) {
    // Do something
}
public static void main(String[] args) {
    int[] s = new int[30];
    exampleMethod(s);
}

Do-While Loops

For-loops can run 0 or more times. If you want something to execute at least once. Use a do-while loop.

do {
    // Code
} while (condition);

For example, to search at least once and asking whether the user wants to search again

// Assume linearSearch and array are defined
char answer;
Scanner input = new Scanner(System.in);
do { 
  linearSearch(array, input);
  System.out.print("Do you want to search again? (Y/N) ");
  input.nextLine();
  answer = input.next().charAt(0);
} while( answer != 'N');

You can create any type of loop just by using a while loop.

Example: Finding the Max

You can find the max of an array using the following method

double max = arrayName[0];
for (int i = 1; i < arrayName.length; i++) {
    if (max < arrayName[i]) {
        max = arrayName[i];
    }
}
System.out.println("The max is " + max);

Example: Summing up an array

You can sum the array using the following method

double sum = 0;
for (int i = 0; i < arrayName.length; i++) {
    sum += arrayName[i];
}
System.out.println("The sum is " + sum);