KEMBAR78
Arrays in JAVA | PDF | Integer (Computer Science) | Data Type
0% found this document useful (0 votes)
20 views15 pages

Arrays in JAVA

Arrays in Java are fundamental data structures that store multiple values of the same type, functioning as objects with fixed lengths and zero-based indexing. They can hold both primitive types and objects, and are dynamically allocated in memory. Key operations include declaration, initialization, and accessing elements, with support for single-dimensional and multi-dimensional arrays.

Uploaded by

l89856238
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
20 views15 pages

Arrays in JAVA

Arrays in Java are fundamental data structures that store multiple values of the same type, functioning as objects with fixed lengths and zero-based indexing. They can hold both primitive types and objects, and are dynamically allocated in memory. Key operations include declaration, initialization, and accessing elements, with support for single-dimensional and multi-dimensional arrays.

Uploaded by

l89856238
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 15

Arrays in Java


Arrays in Java are one of the most fundamental data structures that allow us
to store multiple values of the same type in a single variable. They are useful
for storing and managing collections of data. Arrays in Java are objects, which
makes them work differently from arrays in C/C++ in terms of memory
management. For primitive arrays, elements are stored in a contiguous
memory location, For non-primitive arrays, references are stored at
contiguous locations, but the actual objects may be at different locations in
memory.

Key features of Arrays:


 Contiguous Memory Allocation (for Primitives): Java array elements are
stored in continuous memory locations, which means that the elements are
placed next to each other in memory.
 Zero-based Indexing: The first element of the array is at index 0.
 Fixed Length: Once an array is created, its size is fixed and cannot be
changed.
 Can Store Primitives & Objects: Java arrays can hold both primitive types
(like int, char, boolean, etc.) and objects (like String, Integer, etc.)

Example: This example demonstrates how to initialize an array and traverse it


using a for loop to print each element.

public class Main


{
public static void main(String[] args)
{
int[] arr = { 1, 2, 3, 4, 5 }; // initializing array
int n = arr.length; // size of array
for (int i = 0; i < n; i++) // traversing array
System.out.print(arr[i] + " ");
}
}

Output
1 2 3 4 5
Basics of Arrays in Java
There are some basic operations we can start with.

1. Array Declaration
To declare an array in Java, use the following syntax:

type[] arrayName;
 type: The data type of the array elements (e.g., int, String).
 arrayName: The name of the array.
Note: The array is not yet initialized.

2. Create an Array
To create an array, you need to allocate memory for it using
the new keyword:

Creating an array of 5 integers


int[ ] numbers = new int[5];
This statement initializes the numbers array to hold 5 integers. The default
value for each element is 0.

3. Access an Element of an Array


We can access array elements using their index, which starts from 0:
Setting the first element of the array

numbers[0] = 10;
Accessing the first element

int firstElement = numbers[0];

The first line sets the value of the first element to 10. The second line retrieves
the value of the first element.

4. Change an Array Element


To change an element, assign a new value to a specific index:
Changing the first element to 20

numbers[0] = 20;
5. Array Length
We can get the length of an array using the length property:
Getting the length of the array
int length = numbers.length;
Now, we have completed with basic operations so let us go through the in-
depth concepts of Java Arrays, through the diagrams, examples, and
explanations.

Following are some important points about Java arrays.


Array Properties
 In Java, all arrays are dynamically allocated.
 Arrays may be stored in contiguous memory [consecutive memory
locations].
 Since arrays are objects in Java, we can find their length using the object
property length. This is different from C/C++, where we find length using size
of.
 A Java array variable can also be declared like other variables with [] after
the data type.
 The variables in the array are ordered, and each has an index beginning
with 0.
 Java array can also be used as a static field, a local variable, or a method
parameter.
An array can contain primitives (int, char, etc.) and object (or non-primitive)
references of a class, depending on the definition of the array. In the case of
primitive data types, the actual values might be stored in contiguous memory
locations (JVM does not guarantee this behavior). In the case of class objects.

Note: This storage of arrays helps us randomly access the elements of an array
[Support Random Access].
Creating, Initializing, and Accessing an Arrays in Java

For understanding the array we need to understand how it actually works. To


understand this follow the flow mentioned below:
 Declare
 Initialize
 Access

1. Declaring an Array
The general form of array declaration is
Method : 1
type var-name[];
Method : 2
type[] var-name;
The element type determines the data type of each element that comprises the
array. Like an array of integers, we can also create an array of other primitive
data types like char, float, double, etc., or user-defined data types (objects of a
class).
Note: It is just how we can create is an array variable, no actual array exists.
It merely tells the compiler that this variable (int Array) will hold an array of the
integer type.
Now, Let us provide memory storage to this created array.

2. Initialization an Array in Java


When an array is declared, only a reference of an array is created. The general
form of new as it applies to one-dimensional arrays appears as follows:
var-name = new type [size];

Here, type specifies the type of data being allocated, size determines the
number of elements in the array, and var-name is the name of the array
variable that is linked to the array. To use new to allocate an array, you must
specify the type and number of elements to allocate.
Example:
Declaring array

int intArray[];

Allocating memory to array

intArray = new int[20];

Combining both statements in one

int[] intArray = new int[20];


Note: The elements in the array allocated by new will automatically be
initialized to zero (for numeric types), false (for boolean), or null (for reference
types). Do refer to default array values in Java.
Obtaining an array is a two-step process. First, you must declare a variable of
the desired array type. Second, you must allocate the memory to hold the array,
using new, and assign it to the array variable. Thus, in Java, all arrays are
dynamically allocated.

Array Literal in Java


In a situation where the size of the array and variables of the array are already
known, array literals can be used.
Declaring array literal
int[] intArray = new int[]{ 1,2,3,4,5,6,7,8,9,10 };
 The length of this array determines the length of the created array.
 There is no need to write the new int[] part in the latest versions of Java.
3. Accessing Java Array Elements using for Loop
Now , we have created an Array with or without the values stored in it. Access
becomes an important part to operate over the values mentioned within the
array indexes using the points mentioned below:
 Each element in the array is accessed via its index.
 The index begins with 0 and ends at (total array size)-1.
 All the elements of array can be accessed using Java for Loop.

Let us check the syntax of basic for loop to traverse an array:


Accessing the elements of the specified array

for (int i = 0; i < arr.length; i++)


System.out.println("Element at index " + i + " : "+ arr[i]);
// Java program to illustrate creating an array of integers, puts some values in the
array,
// and prints each value to standard output.

class GFG
{
public static void main(String[] args)
{
int[] arr; // declares an Array of integers.
arr = new int[5]; // allocating memory for 5 integers

// initialize the elements of the array first to last(fifth) element


arr[0] = 10;
arr[1] = 20;
arr[2] = 30;
arr[3] = 40;
arr[4] = 50;

for (int i = 0; i < arr.length; i++) // accessing the elements of the


specified array

System.out.println("Element at index " + i + " : " + arr[i]);


}
}

Output
Element at index 0 : 10
Element at index 1 : 20
Element at index 2 : 30
Element at index 3 : 40
Element at index 4 : 50
Types of Arrays in Java
Java supports different types of arrays:

1. Single-Dimensional Arrays
These are the most common type of arrays, where elements are stored in a
linear order.
A single-dimensional array
int[] singleDimArray = {1, 2, 3, 4, 5};
2. Multi-Dimensional Arrays
Arrays with more than one dimension, such as two-dimensional arrays
(matrices).
A 2D array (matrix)

int[ ][ ] multiDimArray =
{
{1, 2, 3},
{4, 5, 6},
{7, 8, 9} };
.
Arrays of Objects in Java
An array of objects is created like an array of primitive-type data items in the
following way.

Syntax:

Method : 1
ObjectType[] arrName;

Method : 2
ObjectType arrName[];

Example of Arrays of Objects


Example: Here we are taking a student class and creating an array of Student
with five Student objects stored in the array. The Student objects have to be
instantiated using the constructor of the Student class, and their references
should be assigned to the array elements
// Java program to illustrate creating an array of objects

class Student
{
public int roll_no;
public String name;
Student(int roll_no, String name){
this.roll_no = roll_no;
this.name = name;
}
}

public class Main


{
public static void main(String[] args){

Student[] arr; // declares an Array of Student

// allocating memory for 5 objects of type Student.


arr = new Student[5];

// initialize the elements of the array


arr[0] = new Student(1, "aman");
arr[1] = new Student(2, "vaibhav");
arr[2] = new Student(3, "shikar");
arr[3] = new Student(4, "dharmesh");
arr[4] = new Student(5, "mohit");

// accessing the elements of the specified array


for (int i = 0; i < arr.length; i++)
System.out.println("Element at " + i + " : { "
+ arr[i].roll_no + " "
+ arr[i].name+" }");
}
}

Output
Element at 0 : { 1 aman }
Element at 1 : { 2 vaibhav }
Element at 2 : { 3 shikar }
Element at 3 : { 4 dharmesh }
Element at 4 : { 5 mohit }
Example: An array of objects is also created like
// Java program to illustrate creating
// an array of objects

class Student{
public String name;

Student(String name){
this.name = name;
}

@Override
public String toString(){
return name;
}
}

public class Main{


public static void main (String[] args){

// declares an Array and initializing the


// elements of the array
Student[] myStudents = new Student[]{
new Student("Dharma"),new Student("sanvi"),
new Student("Rupa"),new Student("Ajay")
};

// accessing the elements of the specified array


for(Student m:myStudents){
System.out.println(m);
}
}
}

Output
Dharma
sanvi
Rupa
Ajay

Multidimensional Arrays in Java


Multidimensional arrays are arrays of arrays with each element of the array
holding the reference of other arrays. A multidimensional array is created by
appending one set of square brackets ([]) per dimension.
Syntax:
There are 2 methods to declare Java Multidimensional Arrays as mentioned
below:
Method 1

datatype [ ][ ] arrayrefvariable;
Method 2
datatype arrayrefvariable[ ][ ];

Declaration:
// 2D array or matrix
int[][] intArray = new int[10][20];
// 3D array
int[][][] intArray = new int[10][20][10];
Java Multidimensional Arrays Examples
Example: Let us start with basic two dimensional Array declared and initialized.
// Java Program to demonstrate Multidimensional Array

import java.io.*;
class GFG {
public static void main(String[] args){

// Two Dimensional Array Declared and Initialized


int[][] arr = new int[3][3];

// Number of Rows
System.out.println("Rows : " + arr.length);

// Number of Columns
System.out.println("Columns : " + arr[0].length);
}
}

Output
Rows:3
Columns:3

Example: Now, after declaring and initializing the array we will check how to
Traverse the Multidimensional Array using for loop.
// Java Program to Multidimensional Array Driver Class
public class multiDimensional
{
public static void main(String args[]) // main function
{
// declaring and initializing 2D array
int arr[][] = { { 2, 7, 9 }, { 3, 6, 1 }, { 7, 4, 2 } };
// printing 2D array
for (int i = 0; i < 3; i++) {
for (int j = 0; j < 3; j++)
System.out.print(arr[i][j] + " ");
System.out.println();
}
}
}

Output
2 7 9
3 6 1
7 4 2
Passing Arrays to Methods
Like variables, we can also pass arrays to methods. For example, the below
program passes the array to method sum() to calculate the sum of the array's
values.
// Java program to demonstrate assing of array to method

public class Test {


// Driver method
public static void main(String args[ ])
{
int arr[] = { 3, 1, 2, 5, 4 };
sum(arr); // passing array to method m1
}
public static void sum(int[ ] arr)
{
int sum = 0; // getting sum of array values

for (int i = 0; i < arr.length; i++)


sum += arr[i];
System.out.println("sum of array values : " + sum);
}
}

Output
sum of array values : 15

Arrays Types and Their Allowed Element Types


Array Types Allowed Element Types

Any type which can be implicitly promoted


Primitive Type Arrays
to declared type.

Either declared type objects or it's child class


Object Type Arrays
objects.

Abstract Class Type Arrays Its child-class objects are allowed.

Interface Type Arrays Its implementation class objects are allowed.


Common Operations
The below table demonstrates the common array operations
Operation Example

Sort Arrays.sort(arr);

Search Arrays.binarySearch(arr, key);

Copy int[] copy = Arrays.copyOf(arr, len);

Fill Arrays.fill(arr, 0);

Advantages of Java Arrays


 Efficient Access: Accessing an element by its index is fast and has
constant time complexity, O(1).
 Memory Management: Arrays have fixed size, which makes memory
management straightforward and predictable.
 Data Organization: Arrays help organize data in a structured manner,
making it easier to manage related elements.
Disadvantages of Java Arrays
 Fixed Size: Once an array is created, its size cannot be changed, which can
lead to memory waste if the size is overestimated or insufficient storage if
underestimated.
 Type Homogeneity: Arrays can only store elements of the same data type,
which may require additional handling for mixed types of data.
 Insertion and Deletion: Inserting or deleting elements, especially in the
middle of an array, can be costly as it may require shifting elements.
Common Mistakes To Avoid
The common mistakes that can occur when working with arrays in Java are
listed below:
 Accessing Out-of-Bounds Index: When we try to access an index that is
outside the range of the array (i.e, negative index or index greater than or
equal to the array's length) it will thrown an index
ArrayIndexOutOfBoundsException. Always ensure that the index is within
the bounds, which should be between 0 and array.length - 1.
 Assuming Array Size Can Change: Java arrays are fixed in size.
Attempting to change the size of an array (like adding or removing elements)
is not possible directly.
 Not Initializing Array Elements: If we create an array but do not explicitly
initialize its elements, Java will automatically assign default values based on
the type
o For numeric types (e.g., int, double): The default value is 0.
o For boolean arrays: The default value is false.
o For object arrays: The default value is null.

PROBLEMS OF TWO DIMENSIONAL ARRAY

MATRIX ADDITION IN JAVA


Question : Given Two 2D Matrix . Write a Java Program to Add Two Matrix

Sol :
import java.util.Scanner;
public class MatrixAddition
{
public static void main(String[ ] args)
{
Scanner input = new Scanner(System.in);
System.out.print("Enter the number of rows: ");
int rows = input.nextInt();
System.out.print("Enter the number of columns: ");
int cols = input.nextInt();
int[ ][ ] matrix1 = new int[rows][cols];
int[ ][ ] matrix2 = new int[rows][cols];
int[ ][ ] sumMatrix = new int[rows][cols];

System.out.println("Enter elements for Matrix 1:");


for (int i = 0; i < rows; i++)
{
for (int j = 0; j < cols; j++) {
System.out.print("Enter element at (" + (i + 1) + "," + (j + 1) + "): ");
matrix1[i][j] = input.nextInt();
}
}

System.out.println("Enter elements for Matrix 2:");


for (int i = 0; i < rows; i++)
{
for (int j = 0; j < cols; j++)
{
System.out.print("Enter element at (" + (i + 1) + "," + (j + 1) + "): ");
matrix2[i][j] = input.nextInt();
}
}
for (int i = 0; i < rows; i++)
{
for (int j = 0; j < cols; j++)
{
sumMatrix[i][j] = matrix1[i][j] + matrix2[i][j];
}
}
System.out.println("\nSum of the matrices:");
for (int i = 0; i < rows; i++)
{
for (int j = 0; j < cols; j++)
{
System.out.print(sumMatrix[i][j] + " ");
}
System.out.println(); // Move to the next row
}
input.close(); // Close the Scanner
}
}

IInd. Method

// Java program to add two matrices


public class MATRIXADD
{
public static void main(String[] args)
{
// Input matrices
int A[ ][ ] = { { 1, 2 }, { 3, 4 } };
int B[ ][ ] = { { 1, 1 }, { 1, 1 } };

// Dimensions of the matrix


int rows = A.length;
int cols = A[0].length;

// Resultant matrix to store the sum


int sum[ ][ ] = new int[rows][cols];

// Adding two matrices


for (int i = 0; i < rows; i++)
{
for (int j = 0; j < cols; j++)
{
sum[i][j] = A[i][j] + B[i][j];
}
}

// Printing the resultant matrix


System.out.println("Resultant Matrix:");
for (int i = 0; i < rows; i++)
{
for (int j = 0; j < cols; j++)
{
// Print elements on the same line
System.out.print(sum[i][j] + " ");
}
// Move to the next line after printing each row
System.out.println();
}
}
}

TRANSPOSING 2 D MATRIX
Given a 3 x 4 Matrix . Transpose it . i.e., Row and Col elements will exchange

// Java Program to find // transpose of a matrix

class TRANSPOSE
{
static final int M = 3;
static final int N = 4;

// This function stores transpose of A[][] in B[][]


static void transpose(int A[][], int B[][])
{
int i, j;
for (i = 0; i < N; i++)
for (j = 0; j < M; j++)
B[i][j] = A[j][i];
}

// Driver code
public static void main(String[] args)
{
int A[ ][ ] = { { 1, 1, 1, 1 },
{ 2, 2, 2, 2 },
{ 3, 3, 3, 3 } };

int B[][] = new int[N][M], i, j;

transpose(A, B);

System.out.print("Result matrix is \n");


for (i = 0; i < N; i++)
{
for (j = 0; j < M; j++)
System.out.print(B[i][j] + " ");
System.out.print("\n");
}
}
}

Example of Sorting a Single Dimension Array


using System;
namespace Demo
{
public class MyApplication
{
public static void main(string[ ] args) {
int[ ] list = {87, 45, 56, 22, 84, 65};
Console.WriteLine("Original Unsorted List");
foreach (int i in list)
{
Console.Write(i + " ");
}
MyApplication m = new MyApplication();
m.sortFunc(list);
}
public void sortFunc(int[] arr) {
int temp = 0;
Console.WriteLine("Sorted List");
for(int i=0; i < arr.Length; i++)
{
for(int j=i+1; j<arr.Length; j++) {
if(arr[i]>=arr[j])
{
temp=arr[j];
arr[j]=arr[i];
arr[i]=temp;
}
}
Console.Write(arr[i] + " ");
}
}
}
}

You might also like