In this tutorial, we will see how to find the largest element in an array.
Introduction
We will take an array of integers arr
and write a program to find the largest number from arr
. Please note that arr
is not a sorted array. ex. {2, 5, 9, 8, 11}
Java Program to find the largest element in an array
1. Using for loop iteration
In this way, we are iterating over an array using a for loop to find the largest number.
/**
* A Java program to find the largest number in an array
* using for loop iteration.
*
* @author coderolls.com
*
*/
public class LargestElementInArray {
public static void main(String[] args) {
int[] arr = {2, 5, 9, 8, 11};
int largestElement = getLargest(arr);
System.out.println("The largest element in an array 'arr' is: "+ largestElement);
}
private static int getLargest(int[] arr) {
int n = arr.length;
int largest = arr[0];
for(int i=0; i<n; i++) {
//If the number at index i is bigger than the current largest number,
// copy it to 'largest' int variable
if(arr[i]>arr[0]) {
largest = arr[i];
}
}
return largest;
}
}
Output:
The largest element in an array 'arr' is: 11
Explanation:
- In the main method, we have taken a sample array
arr = {2, 5, 9, 8, 11};
and passed it as a parameter to thegetLargest()
method to return the largest number in an arrayarr
. - In the
getLargest()
method we have stored the length of an arrayaar
into int variable n using thearr.length
method and also we have assigned the number at index0
as the current largest number. So we have storedarr[0]
to int variablelargest
. - In a for loop, we are iterating over the array arr and checking if there is a larger number at index
i
than the current largest number. ( We had assignedarr[0]
as the current most significant number to start with in step 2.) - If the number at index
i
is larger than the current largest number i.e.largest
, we will copy it to largest and continue iterating. OR if the number at index i is smaller or equal to the current largest number i.elargest
we will ignore and continue iterating. - At the last, we will return the largest, which has the largest number in an array.
2. Using Arrays.sort()
As the array is not sorted, we can sort it using the Arrays.sort()
method. So the last element of an array will be the largest element of an array.
import java.util.Arrays;
/**
* A Java program to find the largest number in an array
* using Arrays.sort().
*
* Arrays.sort() sort the array in natural sorting order
*
* @author coderolls.com
*
*/
public class LargestElementInArrayUsingArrays {
public static void main(String[] args) {
int[] arr = {2, 5, 9, 8, 11};
int largestElement = getLargest(arr);
System.out.println("The largest element in an array 'arr' "
+ "using Array.sort() is: "+ largestElement);
}
private static int getLargest(int[] arr) {
Arrays.sort(arr);
return arr[arr.length-1];
}
}
Output:
The largest element in an array 'arr' using Array.sort() is:11
Explanation:
- In the main method, we have taken a sample array
arr = {2, 5, 9, 8, 11};
and passed it as a parameter to thegetLargest()
method to return the largest number in an arrayarr
. - In the
getLargest()
method, we have sorted an arrayarr
in natural sorting order using theArrays.sort()
method. - Once we sort the array in natural sorting order, we will have the largest number at the end of the array. We can get the last number of an array as
arr[arr.length-1]
to return it.
3. Using Java 8 Streams API
Java 8 Streams API provides various methods to perform data processing operations on data sources. We can create a stream of an array and the max()
method will return the maximum element of this stream.
import java.util.Arrays;
/**
* A Java program to find the largest number in an array
* using Java 8 Streams API.
*
* max() returns the maximum element of this stream
*
* @author coderolls.com
*
*/
public class LargestElementInArrayUsingStream {
public static void main(String[] args) {
int[] arr = {2, 5, 9, 8, 11};
int largestElement = getLargest(arr);
System.out.println("The largest element in an array 'arr'"
+ "using Java 8 Streams API is: "+ largestElement);
}
private static int getLargest(int[] arr) {
int largest = Arrays.stream(arr).max().getAsInt();
return largest;
}
}
Output:
The largest element in an array 'arr' using Java 8 Streams API is: 11
Explanation:
- In the main method, we have taken a sample array
arr = {2, 5, 9, 8, 11};
and passed it as a parameter to thegetLargest()
method to return the largest number in an arrayarr
. - In the
getLargest()
method, we have created a Stream of arrayarr
. Themax()
returns the maximum element of this stream. We are using thegetAsInt()
method to get the result asint
and store it in the int variablelargest
. - Return the
largest
.
Conclusion:
We have seen a few Java programs to find the largest element in an array.
- We can find the largest element in an array by iterating over an array and comparing each element.
- The second way to find the largest element in an array is by sorting an array in a natural sorting order and returning the last element.
- The third way to find the largest element in an array is by using the Java 8 Streams API’s max method.
The example Java programs used in the above article can be found at this GitHub repository, blogpost-coding-examples/java-programs/largest-element-in-an-array/.
Please write your thoughts in the comment section below.