mirror of
https://github.com/zenorogue/hyperrogue.git
synced 2024-11-30 15:39:54 +00:00
in fieldpattern used const MAXDIST instead of 60; also increased it to 120
This commit is contained in:
parent
b03f23cf65
commit
ef3310f764
@ -341,6 +341,8 @@ struct fpattern {
|
|||||||
DEBB(DF_FIELD, (debugfile, "Built.\n"));
|
DEBB(DF_FIELD, (debugfile, "Built.\n"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const int MAXDIST = 120;
|
||||||
|
|
||||||
vector<char> disthep;
|
vector<char> disthep;
|
||||||
vector<char> disthex;
|
vector<char> disthex;
|
||||||
|
|
||||||
@ -351,7 +353,7 @@ struct fpattern {
|
|||||||
|
|
||||||
int getdist(pair<int,bool> a, vector<char>& dists) {
|
int getdist(pair<int,bool> a, vector<char>& dists) {
|
||||||
if(!a.second) return dists[a.first];
|
if(!a.second) return dists[a.first];
|
||||||
int m = 60;
|
int m = MAXDIST;
|
||||||
int ma = dists[a.first];
|
int ma = dists[a.first];
|
||||||
int mb = dists[connections[btspin(a.first, 3)]];
|
int mb = dists[connections[btspin(a.first, 3)]];
|
||||||
int mc = dists[connections[btspin(a.first, 4)]];
|
int mc = dists[connections[btspin(a.first, 4)]];
|
||||||
@ -373,12 +375,12 @@ struct fpattern {
|
|||||||
|
|
||||||
int maxdist, otherpole, circrad, wallid, wallorder, riverid;
|
int maxdist, otherpole, circrad, wallid, wallorder, riverid;
|
||||||
|
|
||||||
int dijkstra(vector<char>& dists, vector<int> indist[64]) {
|
int dijkstra(vector<char>& dists, vector<int> indist[MAXDIST]) {
|
||||||
int N = connections.size();
|
int N = connections.size();
|
||||||
dists.resize(N);
|
dists.resize(N);
|
||||||
for(int i=0; i<N; i++) dists[i] = 60;
|
for(int i=0; i<N; i++) dists[i] = MAXDIST-1;
|
||||||
int maxd = 0;
|
int maxd = 0;
|
||||||
for(int i=0; i<64; i++) while(!indist[i].empty()) {
|
for(int i=0; i<MAXDIST; i++) while(!indist[i].empty()) {
|
||||||
int at = indist[i].back();
|
int at = indist[i].back();
|
||||||
indist[i].pop_back();
|
indist[i].pop_back();
|
||||||
if(dists[at] <= i) continue;
|
if(dists[at] <= i) continue;
|
||||||
@ -405,7 +407,7 @@ struct fpattern {
|
|||||||
|
|
||||||
markers.resize(N);
|
markers.resize(N);
|
||||||
|
|
||||||
vector<int> indist[64];
|
vector<int> indist[MAXDIST];
|
||||||
|
|
||||||
indist[0].push_back(0);
|
indist[0].push_back(0);
|
||||||
int md0 = dijkstra(disthep, indist);
|
int md0 = dijkstra(disthep, indist);
|
||||||
|
Loading…
Reference in New Issue
Block a user