De-mode std::{treemap,sort}. Part of #3583.
This commit is contained in:
parent
86041c421d
commit
fe62ff465c
@ -5,12 +5,6 @@
|
|||||||
use vec::{len, push};
|
use vec::{len, push};
|
||||||
use core::cmp::{Eq, Ord};
|
use core::cmp::{Eq, Ord};
|
||||||
|
|
||||||
export le;
|
|
||||||
export merge_sort;
|
|
||||||
export quick_sort;
|
|
||||||
export quick_sort3;
|
|
||||||
export Sort;
|
|
||||||
|
|
||||||
type Le<T> = pure fn(v1: &T, v2: &T) -> bool;
|
type Le<T> = pure fn(v1: &T, v2: &T) -> bool;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -19,7 +13,7 @@ type Le<T> = pure fn(v1: &T, v2: &T) -> bool;
|
|||||||
* Has worst case O(n log n) performance, best case O(n), but
|
* Has worst case O(n log n) performance, best case O(n), but
|
||||||
* is not space efficient. This is a stable sort.
|
* is not space efficient. This is a stable sort.
|
||||||
*/
|
*/
|
||||||
fn merge_sort<T: Copy>(le: Le<T>, v: &[const T]) -> ~[T] {
|
pub fn merge_sort<T: Copy>(le: Le<T>, v: &[const T]) -> ~[T] {
|
||||||
type Slice = (uint, uint);
|
type Slice = (uint, uint);
|
||||||
|
|
||||||
return merge_sort_(le, v, (0u, len(v)));
|
return merge_sort_(le, v, (0u, len(v)));
|
||||||
@ -93,7 +87,7 @@ fn qsort<T: Copy>(compare_func: Le<T>, arr: &[mut T], left: uint,
|
|||||||
* Has worst case O(n^2) performance, average case O(n log n).
|
* Has worst case O(n^2) performance, average case O(n log n).
|
||||||
* This is an unstable sort.
|
* This is an unstable sort.
|
||||||
*/
|
*/
|
||||||
fn quick_sort<T: Copy>(compare_func: Le<T>, arr: &[mut T]) {
|
pub fn quick_sort<T: Copy>(compare_func: Le<T>, arr: &[mut T]) {
|
||||||
if len::<T>(arr) == 0u { return; }
|
if len::<T>(arr) == 0u { return; }
|
||||||
qsort::<T>(compare_func, arr, 0u, len::<T>(arr) - 1u);
|
qsort::<T>(compare_func, arr, 0u, len::<T>(arr) - 1u);
|
||||||
}
|
}
|
||||||
@ -155,12 +149,12 @@ fn qsort3<T: Copy Ord Eq>(arr: &[mut T], left: int, right: int) {
|
|||||||
*
|
*
|
||||||
* This is an unstable sort.
|
* This is an unstable sort.
|
||||||
*/
|
*/
|
||||||
fn quick_sort3<T: Copy Ord Eq>(arr: &[mut T]) {
|
pub fn quick_sort3<T: Copy Ord Eq>(arr: &[mut T]) {
|
||||||
if arr.len() <= 1 { return; }
|
if arr.len() <= 1 { return; }
|
||||||
qsort3(arr, 0, (arr.len() - 1) as int);
|
qsort3(arr, 0, (arr.len() - 1) as int);
|
||||||
}
|
}
|
||||||
|
|
||||||
trait Sort {
|
pub trait Sort {
|
||||||
fn qsort(self);
|
fn qsort(self);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -274,7 +268,7 @@ mod tests {
|
|||||||
|
|
||||||
fn check_sort(v1: &[int], v2: &[int]) {
|
fn check_sort(v1: &[int], v2: &[int]) {
|
||||||
let len = vec::len::<int>(v1);
|
let len = vec::len::<int>(v1);
|
||||||
pure fn le(a: &int, b: &int) -> bool { *a <= *b }
|
pub pure fn le(a: &int, b: &int) -> bool { *a <= *b }
|
||||||
let f = le;
|
let f = le;
|
||||||
let v3 = merge_sort::<int>(f, v1);
|
let v3 = merge_sort::<int>(f, v1);
|
||||||
let mut i = 0u;
|
let mut i = 0u;
|
||||||
@ -304,7 +298,7 @@ mod tests {
|
|||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_merge_sort_mutable() {
|
fn test_merge_sort_mutable() {
|
||||||
pure fn le(a: &int, b: &int) -> bool { *a <= *b }
|
pub pure fn le(a: &int, b: &int) -> bool { *a <= *b }
|
||||||
let v1 = ~[mut 3, 2, 1];
|
let v1 = ~[mut 3, 2, 1];
|
||||||
let v2 = merge_sort(le, v1);
|
let v2 = merge_sort(le, v1);
|
||||||
assert v2 == ~[1, 2, 3];
|
assert v2 == ~[1, 2, 3];
|
||||||
|
@ -98,11 +98,8 @@ mod map;
|
|||||||
mod rope;
|
mod rope;
|
||||||
#[legacy_exports]
|
#[legacy_exports]
|
||||||
mod smallintmap;
|
mod smallintmap;
|
||||||
#[legacy_exports]
|
|
||||||
mod sort;
|
mod sort;
|
||||||
#[legacy_exports]
|
|
||||||
mod treemap;
|
mod treemap;
|
||||||
#[legacy_exports]
|
|
||||||
|
|
||||||
// And ... other stuff
|
// And ... other stuff
|
||||||
|
|
||||||
|
@ -12,12 +12,7 @@ use core::cmp::{Eq, Ord};
|
|||||||
use core::option::{Some, None};
|
use core::option::{Some, None};
|
||||||
use Option = core::Option;
|
use Option = core::Option;
|
||||||
|
|
||||||
export TreeMap;
|
pub type TreeMap<K, V> = @mut TreeEdge<K, V>;
|
||||||
export insert;
|
|
||||||
export find;
|
|
||||||
export traverse;
|
|
||||||
|
|
||||||
type TreeMap<K, V> = @mut TreeEdge<K, V>;
|
|
||||||
|
|
||||||
type TreeEdge<K, V> = Option<@TreeNode<K, V>>;
|
type TreeEdge<K, V> = Option<@TreeNode<K, V>>;
|
||||||
|
|
||||||
@ -29,10 +24,10 @@ enum TreeNode<K, V> = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
/// Create a treemap
|
/// Create a treemap
|
||||||
fn TreeMap<K, V>() -> TreeMap<K, V> { @mut None }
|
pub fn TreeMap<K, V>() -> TreeMap<K, V> { @mut None }
|
||||||
|
|
||||||
/// Insert a value into the map
|
/// Insert a value into the map
|
||||||
fn insert<K: Copy Eq Ord, V: Copy>(m: &mut TreeEdge<K, V>, +k: K, +v: V) {
|
pub fn insert<K: Copy Eq Ord, V: Copy>(m: &mut TreeEdge<K, V>, +k: K, +v: V) {
|
||||||
match copy *m {
|
match copy *m {
|
||||||
None => {
|
None => {
|
||||||
*m = Some(@TreeNode({key: k,
|
*m = Some(@TreeNode({key: k,
|
||||||
@ -54,7 +49,7 @@ fn insert<K: Copy Eq Ord, V: Copy>(m: &mut TreeEdge<K, V>, +k: K, +v: V) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Find a value based on the key
|
/// Find a value based on the key
|
||||||
fn find<K: Copy Eq Ord, V: Copy>(m: &const TreeEdge<K, V>, +k: K)
|
pub fn find<K: Copy Eq Ord, V: Copy>(m: &const TreeEdge<K, V>, +k: K)
|
||||||
-> Option<V> {
|
-> Option<V> {
|
||||||
match copy *m {
|
match copy *m {
|
||||||
None => None,
|
None => None,
|
||||||
@ -73,7 +68,7 @@ fn find<K: Copy Eq Ord, V: Copy>(m: &const TreeEdge<K, V>, +k: K)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Visit all pairs in the map in order.
|
/// Visit all pairs in the map in order.
|
||||||
fn traverse<K, V: Copy>(m: &const TreeEdge<K, V>, f: fn((&K), (&V))) {
|
pub fn traverse<K, V: Copy>(m: &const TreeEdge<K, V>, f: fn((&K), (&V))) {
|
||||||
match copy *m {
|
match copy *m {
|
||||||
None => (),
|
None => (),
|
||||||
Some(node) => {
|
Some(node) => {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user