1
0
mirror of https://github.com/zenorogue/hyperrogue.git synced 2025-01-23 15:36:59 +00:00

3d:: binary:: celldistance for heptagons

This commit is contained in:
Zeno Rogue 2019-03-03 00:37:29 +01:00
parent c66858d0b5
commit a30267bad7

View File

@ -372,10 +372,10 @@ bool pseudohept(cell *c) {
return (c->master->zebraval == 1) && (c->master->distance & 1); return (c->master->zebraval == 1) && (c->master->distance & 1);
} }
int celldistance3(cell *c1, cell *c2) { // [untested] int celldistance3(heptagon *c1, heptagon *c2) {
int steps = 0; int steps = 0;
int d1 = celldistAlt(c1); int d1 = c1->distance;
int d2 = celldistAlt(c2); int d2 = c2->distance;
while(d1 > d2) c1 = c1->cmove(8), steps++, d1--; while(d1 > d2) c1 = c1->cmove(8), steps++, d1--;
while(d2 > d1) c2 = c2->cmove(8), steps++, d2--; while(d2 > d1) c2 = c2->cmove(8), steps++, d2--;
vector<int> dx, dy; vector<int> dx, dy;
@ -399,6 +399,8 @@ int celldistance3(cell *c1, cell *c2) { // [untested]
} }
return steps; return steps;
} }
int celldistance3(cell *c1, cell *c2) { return celldistance3(c1->master, c2->master); }
#endif #endif