mirror of
https://github.com/Noratrieb/monte-carlo-tree-search.git
synced 2026-01-14 15:25:09 +01:00
move
This commit is contained in:
parent
f95aeffef7
commit
68abd05376
1 changed files with 68 additions and 0 deletions
68
src/basic_search.rs
Normal file
68
src/basic_search.rs
Normal file
|
|
@ -0,0 +1,68 @@
|
|||
use crate::Node;
|
||||
use std::collections::VecDeque;
|
||||
|
||||
struct Node<T> {
|
||||
value: T,
|
||||
children: Vec<Node<T>>,
|
||||
}
|
||||
|
||||
pub fn breadth_first_search<T: Eq>(tree: &Node<T>, searched: &T) -> bool {
|
||||
let mut candidates = VecDeque::new();
|
||||
candidates.push_back(tree);
|
||||
|
||||
loop {
|
||||
if let Some(candidate) = candidates.pop_front() {
|
||||
if candidate.value == *searched {
|
||||
return true;
|
||||
}
|
||||
|
||||
candidates.extend(candidate.children.iter());
|
||||
} else {
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
false
|
||||
}
|
||||
|
||||
pub fn depth_first_search<T: Eq>(tree: &Node<T>, searched: &T) -> bool {
|
||||
if tree.value == *searched {
|
||||
return true;
|
||||
}
|
||||
|
||||
for child in &tree.children {
|
||||
if depth_first_search(&child, searched) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
false
|
||||
}
|
||||
|
||||
#[cfg(test)]
|
||||
mod tests {
|
||||
use crate::basic_search::{self, Node};
|
||||
use crate::tree;
|
||||
|
||||
#[test]
|
||||
fn dfs() {
|
||||
let tree = tree!(1, tree!(6, tree!(5), tree!(4)), tree!(6));
|
||||
|
||||
let has_seven = basic_search::depth_first_search(&tree, &7);
|
||||
let has_five = basic_search::depth_first_search(&tree, &5);
|
||||
|
||||
assert!(!has_seven);
|
||||
assert!(has_five);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn bfs() {
|
||||
let tree = tree!(1, tree!(6, tree!(5), tree!(4)), tree!(6));
|
||||
|
||||
let has_seven = basic_search::breadth_first_search(&tree, &7);
|
||||
let has_five = basic_search::breadth_first_search(&tree, &5);
|
||||
|
||||
assert!(!has_seven);
|
||||
assert!(has_five);
|
||||
}
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue