i've got directed graph (n, a)
, each node n[i]
has value v[i]
, threshold t[i]
. each arrow (n[i], n[j])
, invariant v[i] <= v[j]
holds. need efficiently implement following operations:
increasethreshold(i, x)
: sett[i] = max(t[i], x)
. that's trivial , completeness here.increasevalue(i, x)
: setv[i] = max(v[i], x)
, increase other values needed above invariant holds.evaluate(i)
: return true ifv[i] < t[i]
the straightforward implementation store v[i]
, t[i]
, , outgoing arrows each node. on increasevalue(i, x)
, it'd propagate value along outgoing arrows (using set of "open" nodes many other graph algorithms do). v[i]
stored each node, evaluate(i)
trivial.
as increasevalue
more frequent other operations, eager approach seems wasteful. wonder, if lazy propagation v[i]
recomputed needed more efficient. this, i'd maintain w[i]
maximum of x
increasevalue(i, x)
, compute v[j]
on fly when evaluate(j)
needs it. can computed maximum of w[i]
on nodes n[i]
there's path n[j]
. actually, once know v[j] >= t[j]
, exact value v[j]
doesn't matter , can stop computation.
unfortunately, lazy algorithm inefficient, doesn't pay off increasevalue
being orders of magnitude more frequent evaluate
.
i imagine, "partially lazy" algorithm better, that's intuition , can't make progress it.
is somehow well-known problem? other idea?
Comments
Post a Comment