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:

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#.