ZetCode

C# array

last modified January 15, 2024

In this article we work with arrays in C#.

Array definition

An array is a collection of data. A scalar variable can hold only one item at a time. Arrays, on the other hand, can hold multiple items. These items are called elements of the array.

Arrays store data of the same data type. Each element can be referred to by an index. The indexes are zero-based. (The index of the first element is zero.) Arrays are reference types.

We declare arrays to be of a certain data type. The Array class holds multiple methods for sorting, finding, modifying array elements.

int[] ages;
String[] names;
float[] weights;

We have three array declarations. The declaration consists of two parts. The type of the array and the array name. The type of an array has a data type that determines the types of the elements within an array (int, String, float in our case) and a pair of square brackets []. The brackets indicate that we have an array.

Collections serve a similar purpose to arrays. They are more powerful than arrays.

C# initializing arrays

There are several ways how we can initialize an array in C#.

Program.cs
int[] vals = new int[5];

vals[0] = 1;
vals[1] = 2;
vals[2] = 3;
vals[3] = 4;
vals[4] = 5;

for (int i = 0; i < vals.Length; i++)
{
    Console.WriteLine(vals[i]);
}

We declare and initialize a numerical array. The contents of the array are printed to the console.

int[] vals = new int[5];

Here we declare an array which contains five elements. All elements are integers.

vals[0] = 1;
vals[1] = 2;
...

We initialize the array with some data. This is assignment initialization. The indexes are in the square brackets. Number 1 is going to be the first element of the array, 2 the second.

for (int i = 0; i < vals.Length; i++)
{
    Console.WriteLine(vals[i]);
}

We go through the array and print its elements. An array has a Length property, which gives the number of elements in the array. Since arrays are zero based, the indexes are 0..length-1.


We can declare and initialize an array in one statement.

Program.cs
int[] array = new int[] { 2, 4, 5, 6, 7, 3, 2 };

foreach (int e in array)
{
    Console.WriteLine(e);
}

This is a modified version of the previous program.

int[] array = new int[] {2, 4, 5, 6, 7, 3, 2 };

An array is declared and initialized in one step. The elements are specified in the curly brackets. We did not specify the length of the array. The compiler will do it for us.

foreach (int e in array)
{
    Console.WriteLine(e);
}

We use the foreach keyword to traverse the array and print its contents.

Simplified initialization syntax

The initialization syntax can be simplified.

Program.cs
int[] array = new int[] { 2, 4, 5, 6, 7, 3, 2 };

foreach (int e in array)
{
    Console.WriteLine(e);
}

Console.WriteLine("------------------------------");

int[] array2 = { 2, 4, 5, 6, 7, 3, 2 };

foreach (int e in array2)
{
    Console.WriteLine(e);
}

The new int[] part can be omitted.

int[] array2 = { 2, 4, 5, 6, 7, 3, 2 };

The int[] array2 = { 2, 4, 5, 6, 7, 3, 2 } is internally compiled to int[] array2 = new int[] { 2, 4, 5, 6, 7, 3, 2 }.

Array initializers

Since .NET 8, we can use collection initializers to initialize arrays. The syntax is both used for arrays and lists.

Program.cs
int[] vals = [1, 2, 3, 4, 5];

for (int i = 0; i < vals.Length; i++)
{
    Console.WriteLine(vals[i]);
}

In the program, we create and initialize the array using the new syntax.

int[] vals = [1, 2, 3, 4, 5];

This syntax is shorter and is common in many programming languages. It is both used for lists.

C# Array.Fill

The Array.Fill method fills the whole array with the given value.

Program.cs
int[] vals = new int[10];

Array.Fill(vals, 0);

Console.WriteLine(string.Join(", ", vals));

We create an array of integers; the array is filled with zeros.

$ dotnet run
0, 0, 0, 0, 0, 0, 0, 0, 0, 0

C# array accessing elements

After an array is created, its elements can be accessed by their index. The index is a number placed inside square brackets which follow the array name.

We can use the index from end ^ operator to get elements from the end of the array. The ^0 equals to array.Length and the ^n to array.Length - n.

Program.cs
string[] names = ["Jane", "Thomas", "Lucy", "David"];

Console.WriteLine(names[0]);
Console.WriteLine(names[1]);
Console.WriteLine(names[2]);
Console.WriteLine(names[3]);

Console.WriteLine("*************************");

Console.WriteLine(names[^1]);
Console.WriteLine(names[^2]);
Console.WriteLine(names[^3]);
Console.WriteLine(names[^4]);

In the example, we create an array of string names. We access each of the elements by its index and print them to the terminal.

string[] names = { "Jane", "Thomas", "Lucy", "David" };

An array of strings is created.

Console.WriteLine(names[0]);
Console.WriteLine(names[1]);
Console.WriteLine(names[2]);
Console.WriteLine(names[3]);

Each of the elements of the array is printed to the console. With the names[0] construct, we refer to the first element of the names array.

Console.WriteLine(names[^1]);
Console.WriteLine(names[^2]);
Console.WriteLine(names[^3]);
Console.WriteLine(names[^4]);

We access array elements from the end.

$ dotnet run
Jane
Thomas
Lucy
David
*************************
David
Lucy
Thomas
Jane

C# implicitly-typed array

C# can infer the type of the array.

Program.cs
var vals = new[] { 1, 2, 3, 4, 5 };
var words = new[] { "cup", "falcon", "word", "water" };

Console.WriteLine(vals.GetType());
Console.WriteLine(words.GetType());

We create two implicitly-typed arrays.

var vals = new[] { 1, 2, 3, 4, 5 };

An array of integers is created. We do not specify the type of the array; the compiler can infer the type from the right side of the assignment. Note that here we cannot use the simplified syntax or the collection initilizers, because we need to tell the compiler the type of the collection.

Console.WriteLine(vals.GetType());
Console.WriteLine(words.GetType());

With GetType, we verify the data types of the arrays.

$ dotnet run
System.Int32[]
System.String[]

C# array modify elements

It is possible to modify the elements of an array - they are not immutable.

Program.cs
int[] vals = [1, 2, 3, 4];

vals[0] *= 2;
vals[1] *= 2;
vals[2] *= 2;
vals[3] *= 2;

Console.WriteLine("[{0}]", string.Join(", ", vals));

We have an array of three integers. Each of the values will be multiplied by two.

int[] vals = [1, 2, 3, 4];

An array of four integers is created.

vals[0] *= 2;
vals[1] *= 2;
vals[2] *= 2;
vals[3] *= 2;

Using the element access, we multiply each value in the array by two.

Console.WriteLine("[{0}]", string.Join(", ", vals));

With the Join method, we create one string from all elements of the array. The elements are separated with a comma character.

$ dotnet run
[2, 4, 6, 8]

All four integers have been multiplied by number 2.

C# array slices

We can use the .. operator to get array slices. A range specifies the start and end of a range. The start of the range is inclusive, but the end of the range is exclusive. It means that the start is included in the range but the end is not included in the range.

Program.cs
int[] vals = [1, 2, 3, 4, 5, 6, 7];

int[] vals2 = vals[1..5];
Console.WriteLine("[{0}]", string.Join(", ", vals2));

int[] vals3 = vals[..6];
Console.WriteLine("[{0}]", string.Join(", ", vals3));

int[] vals4 = vals[3..];
Console.WriteLine("[{0}]", string.Join(", ", vals4));

The example works with array ranges.

int[] vals2 = vals[1..5];

We create an array slice containing elements from index 1 to index 4.

int[] vals3 = vals[..6];

If the start index is omitted, the slice starts from index 0.

int[] vals4 = vals[3..];

If the end index is omitted, the slice goes until the end of the array.

$ dotnet run
[2, 3, 4, 5]
[1, 2, 3, 4, 5, 6]
[4, 5, 6, 7]

C# traversing arrays

We often need to go through all elements of an array. We show two common methods for traversing an array.

Program.cs
string[] planets = [ "Mercury", "Venus", "Mars",
    "Earth", "Jupiter",  "Saturn", "Uranus", "Neptune", "Pluto" ];

for (int i = 0; i < planets.Length; i++)
{
    Console.WriteLine(planets[i]);
}

foreach (string planet in planets)
{
    Console.WriteLine(planet);
}

An array of planet names is created. We use the for and foreach statements to print all the values.

for (int i = 0; i < planets.Length; i++)
{
    Console.WriteLine(planets[i]);
}

In this loop, we utilize the fact that we can get the number of elements from the array object. The number of elements is stored in the Length property.

foreach (string planet in planets)
{
    Console.WriteLine(planet);
}

The foreach statement can be used to make the code more compact when traversing arrays or other collections. In each cycle, the planet variable is passed the next value from the planets array.

C# pass array as function argument

Arrays are passed to functions by reference. This means that the elements of the original array can be changed.

Program.cs
int[] vals = [1, 2, 3, 4, 5];

ModifyArray(vals);

Console.WriteLine(string.Join(", ", vals));

void ModifyArray(int[] data)
{
    Array.Reverse(data);
}

We pass an array of integers to the ModifyArray function. It reverses the array elements. Since a reference to the array is passed and not a copy, the vals array is changed.

$ dotnet run 
5, 4, 3, 2, 1

C# array dimensions

So far, we have worked with one-dimensional arrays. The number of indexes needed to specify an element is called the dimension, or rank of the array.

Two-dimensional array

Next, we work with two-dimensional array.

Program.cs
int[,] twodim = new int[,] { { 1, 2, 3 }, { 1, 2, 3 } };

int d1 = twodim.GetLength(0);
int d2 = twodim.GetLength(1);

for (int i = 0; i < d1; i++)
{
    for (int j = 0; j < d2; j++)
    {
        Console.WriteLine(twodim[i, j]);
    }
}

If we need two indexes to access an element in an array then we have a two dimensional array.

int[,] twodim = new int[,] { { 1, 2, 3 }, { 1, 2, 3 } };

We declare and initialize a two dimensional array in one statement. Note the comma inside the square brackets.

int d1 = twodim.GetLength(0);
int d2 = twodim.GetLength(1);

We get the dimensions of the array. The GetLength gets the number of elements in the specified dimension of the array.

for (int i = 0; i < d1; i++)
{
    for (int j = 0; j < d2; j++)
    {
        Console.WriteLine(twodim[i, j]);
    }
}

We use two for loops to go through all the elements of a two dimensional array. Note that a specific array element is obtained using two indexes, separated by a comma character.

$ dotnet run
1
2
3
1
2
3

We can traverse a two-dimensional array with the foreach loop.

Program.cs
int[,] vals = new int[4, 2]
{
    { 9, 99 },
    { 3, 33 },
    { 4, 44 },
    { 1, 11 }
};

foreach (var val in vals)
{
    Console.WriteLine(val);
}

With the foreach loop, we get the elements one-by-one from the beginning to the end.

$ dotnet run
9
99
3
33
4
44
1
11

Three-dimensional array

Next, we work with a three dimensional array.

Program.cs
int[,,] n3 =
{
    {{12, 2, 8}},
    {{14, 5, 2}},
    {{3, 26, 9}},
    {{4, 11, 2}}
};

int d1 = n3.GetLength(0);
int d2 = n3.GetLength(1);
int d3 = n3.GetLength(2);

for (int i = 0; i < d1; i++)
{
    for (int j = 0; j < d2; j++)
    {
        for (int k = 0; k < d3; k++)
        {
            Console.Write(n3[i, j, k] + " ");
        }
    }
}

Console.Write('\n');

We have a numerical three-dimensional array. Again, we initialize the array with numbers and print them to the terminal.

int[,,] n3 = {
    {{12, 2, 8}},
    {{14, 5, 2}},
    {{3, 26, 9}},
    {{4, 11, 2}}
};

There is another comma between the square brackets on the left side and additional curly brackets on the right side.

for (int k=0; k<d3; k++)
{
    Console.Write(n3[i, j, k] + " ");
}

This loop goes through the third dimension. We use three indexes to retrieve the value from the array.

$ dotnet run
12 2 8 14 5 2 3 26 9 4 11 2

C# Rank

There is a Rank property which gives the number of dimensions of an array.

Program.cs
int[]   a1 = { 1, 2 };
int[,]  a2 = { { 1 }, { 2 } };
int[,,] a3 = { { { 1, 2 }, { 2, 1 } } };

Console.WriteLine(a1.Rank);
Console.WriteLine(a2.Rank);
Console.WriteLine(a3.Rank);

We have three arrays. We use the Rank property to get the number of dimensions for each of them.

Console.WriteLine(a1.Rank);

Here we get the rank for the first array.

$ dotnet run
1
2
3

C# jagged arrays

Arrays that have elements of the same size are called rectangular arrays. In contrast, arrays which have elements of different size are called jagged arrays. Jagged arrays are declared and initialized differently.

Program.cs
int[][] jagged = new int[][]
{
    new int[] { 1, 2 },
    new int[] { 1, 2, 3 },
    new int[] { 1, 2, 3, 4 }
};

foreach (int[] array in jagged)
{
    foreach (int e in array)
    {
        Console.Write(e + " ");
    }
}

Console.Write('\n');

This is an example of a jagged array.

int[][] jagged = new int[][]
{
    new int[] { 1, 2 },
    new int[] { 1, 2, 3 },
    new int[] { 1, 2, 3, 4 }
};

This is a declaration and initialization of a jagged array. Note that this time, we use two pairs of square brackets. We have an array of arrays. More specifically, we have declared an array to have three arrays of int data type. Each of the arrays has different number of elements.

foreach (int[] array in jagged)
{
    foreach (int e in array)
    {
        Console.Write(e + " ");
    }
}

We use two foreach loops to traverse the jagged array. In the first loop, we get the array. In the second loop, we get the elements of the obtained array.

C# array sort & reverse

The Array.sort method sorts the array elements in-place. The Array.Reverse method reverses the sequence of the array elements.

Program.cs
string[] names = ["Jane", "Frank", "Alice", "Tom"];

Array.Sort(names);

foreach (string e in names)
{
    Console.Write(e + " ");
}

Console.Write('\n');

Array.Reverse(names);

foreach (string e in names)
{
    Console.Write(e + " ");
}

Console.Write('\n');

In this example, we sort and reverse an array of strings.

string[] names = ["Jane", "Frank", "Alice", "Tom"];

We have an array of strings.

Array.Sort(names);

The static Sort method sorts the data alphabetically.

Array.Reverse(names);

The Reverse method reverses the sequence of the elements in the entire one-dimensional array.

$ dotnet run
Alice Frank Jane Tom
Tom Jane Frank Alice

Alternatively, we can sort arrays with LINQ's Order and OrderDescending methods.

Program.cs
string[] names = ["Jane", "Frank", "Alice", "Tom"];

var sorted = names.Order();

foreach (var name in sorted)
{
    Console.WriteLine(name);
}

Console.WriteLine("----------------------");

var sorted2 = names.OrderDescending();

foreach (var name in sorted2)
{
    Console.WriteLine(name);
}

The program sorts an array of strings in ascending and descending orders.

$ dotnet run
Alice
Frank
Jane
Tom
----------------------
Tom
Jane
Frank
Alice

C# array GetValue & SetValue

The SetValue method sets a value to the element at the specified position. The GetValue gets the value at the specified position.

Program.cs
string[] names = ["Jane", "Frank", "Alice", "Tom"];

names.SetValue("Beky", 1);
names.SetValue("Erzebeth", 3);

Console.WriteLine(names.GetValue(1));
Console.WriteLine(names.GetValue(3));

This example uses the SetValue and GetValue methods.

names.SetValue("Beky", 1);
names.SetValue("Erzebeth", 3);

The SetValue sets a value for a specific index in the array.

Console.WriteLine(names.GetValue(1));
Console.WriteLine(names.GetValue(3));

We retrieve the values from the array with the GetValue method.

$ dotnet run
Beky
Erzebeth

C# array Clone & Clear

The Array.Copy method copies values from the source array to the destination array. The Array.Clear deletes all elements of the array.

Program.cs
string[] names = ["Jane", "Frank", "Alice", "Tom"];
string[] names2 = new string[4];

Array.Copy(names, names2, names.Length);

Console.WriteLine(string.Join(", ", names2));

Array.Clear(names2);

Console.WriteLine(string.Join(", ", names2));

In the program, we create a copy of an array and later delete it.

Array.Copy(names, names2, names.Length);

The Copy method copies values from the source array to the destination array. The first parameter is the source array, the second is the destination array. The third parameter is the length; it specifies the number of elements to copy.

Array.Clear(names2);

The Clear method removes all elements from the array.

$ dotnet run
Jane, Frank, Alice, Tom
, , , 

Source

Arrays - language reference

In this article we have worked with arrays in C#.

Author

My name is Jan Bodnar and I am a passionate programmer with many years of programming experience. I have been writing programming articles since 2007. So far, I have written over 1400 articles and 8 e-books. I have over eight years of experience in teaching programming.

List all C# tutorials.