Sha256: 420fea306333b429ad642885f0720235e67b9ab9ec689a003d75d192d1b4e459

Contents?: true

Size: 820 Bytes

Versions: 208

Compression:

Stored size: 820 Bytes

Contents

public static class BinarySearch
{
    public static int Search(int[] input, int target)
    {
        if (input.Length == 0)
        {
            return -1;
        }
        
        return SearchHelper(input, target, 0, input.Length - 1);
    }

    public static int SearchHelper(int[] input, int target, int minIndex, int maxIndex)
    {
        var middleIndex = (minIndex + maxIndex) / 2;

        if (input[middleIndex] == target)
        {
            return middleIndex;
        }

        if (middleIndex <= 0 || middleIndex >= input.Length - 1)
        {
            return -1;
        }

        if (input[middleIndex] > target)
        {
            return SearchHelper(input, target, minIndex, middleIndex - 1);
        }

        return SearchHelper(input, target, middleIndex + 1, maxIndex);
    }
}

Version data entries

208 entries across 208 versions & 1 rubygems

Version Path
trackler-2.1.0.53 tracks/csharp/exercises/binary-search/Example.cs
trackler-2.1.0.52 tracks/csharp/exercises/binary-search/Example.cs
trackler-2.1.0.51 tracks/csharp/exercises/binary-search/Example.cs
trackler-2.1.0.50 tracks/csharp/exercises/binary-search/Example.cs
trackler-2.1.0.49 tracks/csharp/exercises/binary-search/Example.cs
trackler-2.1.0.48 tracks/csharp/exercises/binary-search/Example.cs
trackler-2.1.0.47 tracks/csharp/exercises/binary-search/Example.cs
trackler-2.1.0.46 tracks/csharp/exercises/binary-search/Example.cs
trackler-2.1.0.45 tracks/csharp/exercises/binary-search/Example.cs
trackler-2.1.0.44 tracks/csharp/exercises/binary-search/Example.cs
trackler-2.1.0.43 tracks/csharp/exercises/binary-search/Example.cs
trackler-2.1.0.42 tracks/csharp/exercises/binary-search/Example.cs
trackler-2.1.0.41 tracks/csharp/exercises/binary-search/Example.cs
trackler-2.1.0.40 tracks/csharp/exercises/binary-search/Example.cs
trackler-2.1.0.39 tracks/csharp/exercises/binary-search/Example.cs
trackler-2.1.0.38 tracks/csharp/exercises/binary-search/Example.cs
trackler-2.1.0.37 tracks/csharp/exercises/binary-search/Example.cs
trackler-2.1.0.36 tracks/csharp/exercises/binary-search/Example.cs
trackler-2.1.0.34 tracks/csharp/exercises/binary-search/Example.cs
trackler-2.1.0.33 tracks/csharp/exercises/binary-search/Example.cs