master > master: code-rs - minor
This commit is contained in:
parent
dc831a91c7
commit
5be654e5db
@ -48,7 +48,7 @@ fn tarjan_visit<T>(gph: &Graph<T>, &u: &T, ctx: &mut Context<T>)
|
||||
{
|
||||
// Place node on stack + initialise visit-index + component-index.
|
||||
ctx.max_index += 1;
|
||||
ctx.push(&u);
|
||||
ctx.stack_push(&u);
|
||||
ctx.set_root(&u, ctx.max_index);
|
||||
ctx.set_index(&u, ctx.max_index);
|
||||
ctx.set_state(&u, State::PENDING);
|
||||
@ -63,18 +63,19 @@ fn tarjan_visit<T>(gph: &Graph<T>, &u: &T, ctx: &mut Context<T>)
|
||||
tarjan_visit(gph, &v, ctx);
|
||||
}
|
||||
// Update associated component-index of parent node, if in same component as child:
|
||||
if ctx.stack.contains(&v) {
|
||||
if ctx.stack_contains(&v) {
|
||||
ctx.set_root(&u, value_min!(ctx.get_root(&u), ctx.get_root(&v)));
|
||||
}
|
||||
}
|
||||
ctx.set_state(&u, State::FINISHED);
|
||||
ctx.log_info(&u);
|
||||
|
||||
// If at root of component pop everything from stack up to root and add component:
|
||||
if ctx.get_index(&u) == ctx.get_root(&u) {
|
||||
let mut component: Vec<T> = Vec::new();
|
||||
loop {
|
||||
let v = ctx.top();
|
||||
ctx.pop();
|
||||
let v = ctx.stack_top();
|
||||
ctx.stack_pop();
|
||||
component.push(v.clone());
|
||||
if u == v { break; }
|
||||
}
|
||||
@ -119,15 +120,15 @@ impl<T> Context<T>
|
||||
};
|
||||
}
|
||||
|
||||
fn push(self: &mut Self, u: &T) {
|
||||
fn stack_push(self: &mut Self, u: &T) {
|
||||
self.stack.push(u.clone());
|
||||
}
|
||||
|
||||
fn top(self: &mut Self) -> T {
|
||||
fn stack_top(self: &mut Self) -> T {
|
||||
return self.stack.top();
|
||||
}
|
||||
|
||||
fn pop(self: &mut Self) -> T {
|
||||
fn stack_pop(self: &mut Self) -> T {
|
||||
return self.stack.pop();
|
||||
}
|
||||
|
||||
@ -153,6 +154,10 @@ impl<T> Context<T>
|
||||
self.update_infos(u, info);
|
||||
}
|
||||
|
||||
fn stack_contains(self: &Self, u: &T) -> bool {
|
||||
return self.stack.contains(u);
|
||||
}
|
||||
|
||||
fn get_info(self: &Self, u: &T) -> NodeInformation<T> {
|
||||
return *self.infos.get(u).unwrap();
|
||||
}
|
||||
|
@ -55,7 +55,7 @@ fn fixture_graph3() -> graph::Graph<i32> {
|
||||
}
|
||||
|
||||
// ----------------------------------------------------------------
|
||||
// Test Graph
|
||||
// Test Tarjan-Algorithm
|
||||
// ----------------------------------------------------------------
|
||||
|
||||
#[rstest]
|
||||
|
@ -7,10 +7,6 @@ extern crate closure;
|
||||
|
||||
use ads2::stacks::stack;
|
||||
|
||||
// ----------------------------------------------------------------
|
||||
// Test regex
|
||||
// ----------------------------------------------------------------
|
||||
|
||||
// ----------------------------------------------------------------
|
||||
// Test stack
|
||||
// ----------------------------------------------------------------
|
||||
|
Loading…
x
Reference in New Issue
Block a user