En este post de programación con C# te mostraré cómo buscar un elemento en un array. De este modo vamos a saber si un arreglo contiene determinado elemento, y si lo contiene, sabremos en qué posición está.

Básicamente vamos a buscar el índice que un elemento tiene dentro de un arreglo de C sharp. Te mostraré dos formas: una usando métodos que ya existen y otra que es una forma manual.

Con Array.IndexOf

El método Array.IndexOf de C# nos devuelve el índice que el elemento ocupa dentro del arreglo, o -1 en caso de que no exista. Su sintaxis es:

Posible índice = Array.IndexOf(arreglo, búsqueda);

Aquí un ejemplo:

using System;

namespace App
{
    class Programa
    {
        static void Main(string[] args)
        {
            int[] numeros = { 999, 28, 11, 96, 1, 2, 45, 0, 1 };
            int busqueda = 855;
            int indice = Array.IndexOf(numeros, busqueda);
            if (indice == -1)
            {
                Console.WriteLine("El elemento {0} no existe", busqueda);
            }
            else
            {
                Console.WriteLine("El elemento {0} existe en la posición {1}", busqueda, indice);
            }
        }
    }
}

En este caso la búsqueda no existe, lo he hecho a propósito para demostrarlo, pero si cambias el valor verás que funciona. Esto igualmente funciona para otros tipos de arreglo.

Buscar en array de C# manualmente

Nosotros podemos fabricar nuestro propio IndexOf. Básicamente tenemos que recorrer el arreglo e ir comparando cada elemento con la búsqueda.

Si encontramos el elemento que buscamos, devolvemos el índice en el que vamos. En caso de terminar de recorrer el arreglo y no encontrar lo que buscamos, devolvemos -1. Eso se traduce al siguiente código:

using System;
// https://parzibyte.me/blog/

namespace App
{
    class Programa
    {

        static int buscarIndice(int[] arreglo, int busqueda)
        {
            for (int i = 0; i < arreglo.Length; i++)
            {
                if (arreglo[i] == busqueda)
                {
                    return i;
                }
            }
            return -1;
        }
        static void Main(string[] args)
        {
            int[] numeros = { 999, 28, 11, 96, 1, 2, 45, 0, 1 };
            int busqueda = 11;
            int indice = buscarIndice(numeros, busqueda);
            if (indice == -1)
            {
                Console.WriteLine("El elemento {0} no existe", busqueda);
            }
            else
            {
                Console.WriteLine("El elemento {0} existe en la posición {1}", busqueda, indice);
            }
        }
    }
}

En este caso el ejemplo que te he mostrado es con enteros, pero eso funcionará con cualquier tipo de dato siempre y cuando sepamos compararlo correctamente; incluso podríamos usar genéricos.

Al momento de ejecutarlo en mi caso aparece lo siguiente:

Buscar elemento en arreglo de C# - Nuestro IndexOf

Así que funciona perfectamente, pues con esto puedes saber si el arreglo contiene o no el elemento, y si lo contiene, tendrás el índice para saber su posición.

Hay otras variantes que por ejemplo buscan el último índice (recorriendo el arreglo de fin a principio), esto es útil cuando el arreglo puede tener repetidos, pues IndexOf regresa el índice del primer elemento.

Para terminar te dejo con más tutoriales de C sharp o C#.

Si el post ha sido de tu agrado te invito a que me sigas para saber cuando haya escrito un nuevo post, haya actualizado algún sistema o publicado un nuevo software. Facebook | X | Instagram | Telegram | También estoy a tus órdenes para cualquier contratación en mi página de contacto