Change FloodFill-Algorithm to get Voronoi Territory for two data points?

前端 未结 1 1098
天涯浪人
天涯浪人 2020-12-20 09:10

I got a grid with two points. I want to calculate the amount squares each point can reach before the other. Currently I implement a FloodFill-Algoritm, which can calculate t

相关标签:
1条回答
  • 2020-12-20 09:30

    What do you mean by "each point can reach before the other"?

    It looks to me like you need a BF search. Use a FIFO queue like so:

    Let p1 and p2 be the positions of the two points.

    let f be the first element in the queue and l the last. Initially f = 0, l = 1. Let Q be the queue.

    Q[f] = p1
    Q[l] = p2
    while ( f <= l )
    {
       poz = Q[f];
       ++f;
    
       for each neighbour poz' of poz
          if poz' hasn't been marked yet
          {
             mark poz'
             add poz' to Q: Q[++l] = poz
          }
    }
    

    Q will need to be the size of your grid (rows x cols). You can use two matrices: one with the positions p1 can reach and the other with the positions p2 can reach, or you can use one matrix and mark the squares p1 reaches with positive numbers and the squares p2 reaches with negative numbers. If you are interested where they meet, you just need to check if you are about to mark a positive value from a negative value (poz negative and poz' positive) or the other way around. This will basically do your flooding in turns: flood one square from p1, then from p2, then from p1, then from p2 and so on.

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