проблема
У меня есть массив java.awt.Rectangle
с. Для тех, кто не знаком с этим классом, важной информацией является то, что они предоставляют функцию .intersects(Rectangle b)
.
Я хотел бы написать функцию, которая принимает этот массив Rectangle
с и разбивает его на группы связанных прямоугольников.
Допустим, например, что это мои прямоугольники (конструктор принимает аргументы x
, y
, width
, height
):
Rectangle[] rects = new Rectangle[]
{
new Rectangle(0, 0, 4, 2), //A
new Rectangle(1, 1, 2, 4), //B
new Rectangle(0, 4, 8, 2), //C
new Rectangle(6, 0, 2, 2) //D
}
Быстрый рисунок показывает, что A пересекает B, а B пересекает C. D ничего не пересекает. Утомительно нарисованное произведение искусства ascii тоже делает свою работу:
┌───────┐ ╔═══╗
│A╔═══╗ │ ║ D ║
└─╫───╫─┘ ╚═══╝
║ B ║
┌─╫───╫─────────┐
│ ╚═══╝ C │
└───────────────┘
Поэтому вывод моей функции должен быть:
new Rectangle[][]{
new Rectangle[] {A,B,C},
new Rectangle[] {D}
}
Код ошибки
Это была моя попытка решить проблему:
public List<Rectangle> getIntersections(ArrayList<Rectangle> list, Rectangle r)
{
List<Rectangle> intersections = new ArrayList<Rectangle>();
for(Rectangle rect : list)
{
if(r.intersects(rect))
{
list.remove(rect);
intersections.add(rect);
intersections.addAll(getIntersections(list, rect));
}
}
return intersections;
}
public List<List<Rectangle>> mergeIntersectingRects(Rectangle... rectArray)
{
List<Rectangle> allRects = new ArrayList<Rectangle>(rectArray);
List<List<Rectangle>> groups = new ArrayList<ArrayList<Rectangle>>();
for(Rectangle rect : allRects)
{
allRects.remove(rect);
ArrayList<Rectangle> group = getIntersections(allRects, rect);
group.add(rect);
groups.add(group);
}
return groups;
}
К сожалению, здесь, кажется, происходит бесконечный цикл рекурсии. Мое необразованное предположение, что ява не любит, когда я делаю это:
for(Rectangle rect : allRects)
{
allRects.remove(rect);
//...
}
Может кто-нибудь пролить свет на проблему?