CRoadRandomizer.h 831 B

12345678910111213141516171819202122232425262728293031323334353637383940
  1. /*
  2. * CRoadRandomizer.h, part of VCMI engine
  3. *
  4. * Authors: listed in file AUTHORS in main folder
  5. *
  6. * License: GNU General Public License v2.0 or later
  7. * Full text of license available in license.txt file, in main folder
  8. *
  9. */
  10. #pragma once
  11. #include "../GameConstants.h"
  12. VCMI_LIB_NAMESPACE_BEGIN
  13. namespace vstd
  14. {
  15. class RNG;
  16. }
  17. class RmgMap;
  18. class CRoadRandomizer
  19. {
  20. public:
  21. explicit CRoadRandomizer(RmgMap & map);
  22. ~CRoadRandomizer() = default;
  23. void dropRandomRoads(vstd::RNG * rand);
  24. private:
  25. RmgMap & map;
  26. };
  27. // Helper functions for Union-Find (Disjoint Set Union)
  28. TRmgTemplateZoneId findSet(std::map<TRmgTemplateZoneId, TRmgTemplateZoneId> & parent, TRmgTemplateZoneId x);
  29. void unionSets(std::map<TRmgTemplateZoneId, TRmgTemplateZoneId> & parent, TRmgTemplateZoneId x, TRmgTemplateZoneId y);
  30. VCMI_LIB_NAMESPACE_END