mirror of
https://github.com/servo/servo.git
synced 2025-08-06 14:10:11 +01:00
Add some binary search methods and tests for to servo::util::vec.
This commit is contained in:
parent
417dbf0fc0
commit
1f7c5caa43
3 changed files with 107 additions and 1 deletions
|
@ -130,12 +130,14 @@ mod resource {
|
||||||
}
|
}
|
||||||
|
|
||||||
mod util {
|
mod util {
|
||||||
mod tree;
|
|
||||||
mod color;
|
mod color;
|
||||||
mod time;
|
mod time;
|
||||||
|
mod tree;
|
||||||
mod url;
|
mod url;
|
||||||
|
mod vec;
|
||||||
}
|
}
|
||||||
|
|
||||||
mod opts;
|
mod opts;
|
||||||
|
|
||||||
|
use servo_util = util;
|
||||||
use servo_text = text;
|
use servo_text = text;
|
||||||
|
|
|
@ -1,3 +1,5 @@
|
||||||
|
use core::vec;
|
||||||
|
|
||||||
// A generic tree datatype.
|
// A generic tree datatype.
|
||||||
//
|
//
|
||||||
// TODO: Use traits.
|
// TODO: Use traits.
|
||||||
|
|
102
src/servo/util/vec.rs
Normal file
102
src/servo/util/vec.rs
Normal file
|
@ -0,0 +1,102 @@
|
||||||
|
use core::cmp::{Ord, Eq};
|
||||||
|
|
||||||
|
export BinarySearchMethods, binary_search, binary_search_index;
|
||||||
|
|
||||||
|
trait BinarySearchMethods<T: Ord Eq> {
|
||||||
|
pure fn binary_search(&self, key: &T) -> Option<&self/T>;
|
||||||
|
pure fn binary_search_index(&self, key: &T) -> Option<uint>;
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<T: Ord Eq> &[T]: BinarySearchMethods<T> {
|
||||||
|
pure fn binary_search(&self, key: &T) -> Option<&self/T> {
|
||||||
|
match self.binary_search_index(key) {
|
||||||
|
None => None,
|
||||||
|
Some(i) => Some(&self[i])
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pure fn binary_search_index(&self, key: &T) -> Option<uint> {
|
||||||
|
if self.len() == 0 {
|
||||||
|
return None;
|
||||||
|
}
|
||||||
|
|
||||||
|
let mut low : int = 0;
|
||||||
|
let mut high : int = (self.len() as int) - 1;
|
||||||
|
|
||||||
|
while (low <= high) {
|
||||||
|
// http://googleresearch.blogspot.com/2006/06/extra-extra-read-all-about-it-nearly.html
|
||||||
|
let mid : int = (((low as uint) + (high as uint)) >> 1) as int;
|
||||||
|
let midv = &self[mid];
|
||||||
|
|
||||||
|
if (midv < key) {
|
||||||
|
low = mid + 1;
|
||||||
|
} else if (midv > key) {
|
||||||
|
high = mid - 1;
|
||||||
|
} else {
|
||||||
|
return Some(mid as uint);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return None;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn test_find_all_elems<T: Eq Ord>(arr: &[T]) {
|
||||||
|
let mut i = 0;
|
||||||
|
while i < arr.len() {
|
||||||
|
assert test_match(&arr[i], arr.binary_search(&arr[i]));
|
||||||
|
i += 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn test_miss_all_elems<T: Eq Ord>(arr: &[T], misses: &[T]) {
|
||||||
|
let mut i = 0;
|
||||||
|
while i < misses.len() {
|
||||||
|
let res = arr.binary_search(&misses[i]);
|
||||||
|
debug!("%? == %? ?", misses[i], res);
|
||||||
|
assert !test_match(&misses[i], arr.binary_search(&misses[i]));
|
||||||
|
i += 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn test_match<T: Eq>(b: &T, a: Option<&T>) -> bool {
|
||||||
|
match a {
|
||||||
|
None => false,
|
||||||
|
Some(t) => t == b
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn should_find_all_elements() {
|
||||||
|
#[test];
|
||||||
|
|
||||||
|
let arr_odd = [1, 2, 4, 6, 7, 8, 9];
|
||||||
|
let arr_even = [1, 2, 5, 6, 7, 8, 9, 42];
|
||||||
|
let arr_double = [1, 1, 2, 2, 6, 8, 22];
|
||||||
|
let arr_one = [234986325];
|
||||||
|
let arr_two = [3044, 8393];
|
||||||
|
let arr_three = [12, 23, 34];
|
||||||
|
|
||||||
|
test_find_all_elems(arr_odd);
|
||||||
|
test_find_all_elems(arr_even);
|
||||||
|
test_find_all_elems(arr_double);
|
||||||
|
test_find_all_elems(arr_one);
|
||||||
|
test_find_all_elems(arr_two);
|
||||||
|
test_find_all_elems(arr_three);
|
||||||
|
}
|
||||||
|
|
||||||
|
fn should_not_find_missing_elements() {
|
||||||
|
#[test];
|
||||||
|
|
||||||
|
let arr_odd = [1, 2, 4, 6, 7, 8, 9];
|
||||||
|
let arr_even = [1, 2, 5, 6, 7, 8, 9, 42];
|
||||||
|
let arr_double = [1, 1, 2, 2, 6, 8, 22];
|
||||||
|
let arr_one = [234986325];
|
||||||
|
let arr_two = [3044, 8393];
|
||||||
|
let arr_three = [12, 23, 34];
|
||||||
|
|
||||||
|
test_miss_all_elems(arr_odd, [-22, 0, 3, 5, 34938, 10, 11, 12]);
|
||||||
|
test_miss_all_elems(arr_even, [-1, 0, 3, 34938, 10, 11, 12]);
|
||||||
|
test_miss_all_elems(arr_double, [-1, 0, 3, 4, 34938, 10, 11, 12, 234, 234, 33]);
|
||||||
|
test_miss_all_elems(arr_one, [-1, 0, 3, 34938, 10, 11, 12, 234, 234, 33]);
|
||||||
|
test_miss_all_elems(arr_two, [-1, 0, 3, 34938, 10, 11, 12, 234, 234, 33]);
|
||||||
|
test_miss_all_elems(arr_three, [-2, 0, 1, 2, 3, 34938, 10, 11, 234, 234, 33]);
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue