Sliding window algorithm in C#

后端 未结 1 446
南旧
南旧 2021-01-16 14:30

I\'m trying to implement simple sliding window alogirithm on two-dimensional array in C# 3.0, I found this as very useful but it involves only single-dimensioal array.

相关标签:
1条回答
  • 2021-01-16 15:07

    Naive implementation:

    private static IEnumerable<T[,]> GetWindows<T>(
        T[,] array,
        int windowWidth,
        int windowHeight)
    {
        for (var y = 0; y < array.GetLength(1) - windowHeight + 1; y++)
        {
            for (var x = 0; x < array.GetLength(0) - windowWidth + 1; x++)
            {
                var slice = new T[windowWidth, windowHeight];
                CopyArray(array, x, y, slice, 0, 0, windowWidth, windowHeight);
                yield return slice;
            }
        }
    }
    

    Helper method to copy between two-dimensional arrays:

    private static void CopyArray<T>(
        T[,] src, int srcX, int srcY,
        T[,] dst, int dstX, int dstY,
        int width, int height)
    {
        for (var x = 0; x < width; x++)
        {
            for (var y = 0; y < height; y++)
            {
                dst[dstX + x, dstY + y] = src[srcX + x, srcY + y];
            }
        }
    }
    

    Test main:

    private static void Main(string[] args)
    {
        var array = new string[5, 5];
        for (var y = 0; y < array.GetLength(1); y++)
        {
            for (var x = 0; x < array.GetLength(0); x++)
            {
                array[x, y] = string.Format("({0}|{1})", x, y);
            }
        }
        foreach (var window in GetWindows(array, 3, 3))
        {
            ShowArray(window);
        }
        Console.ReadLine();
    }
    
    private static void ShowArray<T>(T[,] array)
    {
        for (var x = 0; x < array.GetLength(0); x++)
        {
            for (var y = 0; y < array.GetLength(1); y++)
            {
                Console.Write("    {0}", array[x, y]);
            }
            Console.WriteLine();
        }
        Console.WriteLine();
    }
    

    Output:

    (0|0)    (0|1)    (0|2)
    (1|0)    (1|1)    (1|2)
    (2|0)    (2|1)    (2|2)
    
    (1|0)    (1|1)    (1|2)
    (2|0)    (2|1)    (2|2)
    (3|0)    (3|1)    (3|2)
    
    (2|0)    (2|1)    (2|2)
    (3|0)    (3|1)    (3|2)
    (4|0)    (4|1)    (4|2)
    
    (0|1)    (0|2)    (0|3)
    (1|1)    (1|2)    (1|3)
    (2|1)    (2|2)    (2|3)
    
    (1|1)    (1|2)    (1|3)
    (2|1)    (2|2)    (2|3)
    (3|1)    (3|2)    (3|3)
    
    (2|1)    (2|2)    (2|3)
    (3|1)    (3|2)    (3|3)
    (4|1)    (4|2)    (4|3)
    
    (0|2)    (0|3)    (0|4)
    (1|2)    (1|3)    (1|4)
    (2|2)    (2|3)    (2|4)
    
    (1|2)    (1|3)    (1|4)
    (2|2)    (2|3)    (2|4)
    (3|2)    (3|3)    (3|4)
    
    (2|2)    (2|3)    (2|4)
    (3|2)    (3|3)    (3|4)
    (4|2)    (4|3)    (4|4)
    

    Now all you have to do is apply the same technique as shown in that blog post :)

    0 讨论(0)
提交回复
热议问题