| ... | ... |
@@ -718,49 +718,49 @@ |
| 718 | 718 |
} |
| 719 | 719 |
|
| 720 | 720 |
/// \brief Inserts the given element into the given component. |
| 721 | 721 |
/// |
| 722 | 722 |
/// This methods inserts the element \e item a into the \e cls class. |
| 723 | 723 |
void insert(const Item& item, int cls) {
|
| 724 | 724 |
int idx = newItem(); |
| 725 | 725 |
int rdx = classes[cls].firstItem; |
| 726 | 726 |
items[idx].item = item; |
| 727 | 727 |
items[idx].cls = cls; |
| 728 | 728 |
|
| 729 | 729 |
items[idx].prev = rdx; |
| 730 | 730 |
items[idx].next = items[rdx].next; |
| 731 | 731 |
items[items[rdx].next].prev = idx; |
| 732 | 732 |
items[rdx].next = idx; |
| 733 | 733 |
|
| 734 | 734 |
index.set(item, idx); |
| 735 | 735 |
} |
| 736 | 736 |
|
| 737 | 737 |
/// \brief Clears the union-find data structure |
| 738 | 738 |
/// |
| 739 | 739 |
/// Erase each item from the data structure. |
| 740 | 740 |
void clear() {
|
| 741 | 741 |
items.clear(); |
| 742 |
classes.clear; |
|
| 742 |
classes.clear(); |
|
| 743 | 743 |
firstClass = firstFreeClass = firstFreeItem = -1; |
| 744 | 744 |
} |
| 745 | 745 |
|
| 746 | 746 |
/// \brief Gives back the class of the \e item. |
| 747 | 747 |
/// |
| 748 | 748 |
/// Gives back the class of the \e item. |
| 749 | 749 |
int find(const Item &item) const {
|
| 750 | 750 |
return items[index[item]].cls; |
| 751 | 751 |
} |
| 752 | 752 |
|
| 753 | 753 |
/// \brief Gives back a representant item of the component. |
| 754 | 754 |
/// |
| 755 | 755 |
/// Gives back a representant item of the component. |
| 756 | 756 |
Item item(int cls) const {
|
| 757 | 757 |
return items[classes[cls].firstItem].item; |
| 758 | 758 |
} |
| 759 | 759 |
|
| 760 | 760 |
/// \brief Removes the given element from the structure. |
| 761 | 761 |
/// |
| 762 | 762 |
/// Removes the element from its component and if the component becomes |
| 763 | 763 |
/// empty then removes that component from the component list. |
| 764 | 764 |
/// |
| 765 | 765 |
/// \warning It is an error to remove an element which is not in |
| 766 | 766 |
/// the structure. |
0 comments (0 inline)