Skip to content

Commit

Permalink
Auto merge of #93765 - zhangyunhao116:heapsort, r=m-ou-se
Browse files Browse the repository at this point in the history
Optimize heapsort

The new implementation is about 10% faster than the previous one(sorting random 1000 items).
  • Loading branch information
bors committed Jun 20, 2022
2 parents b12708f + 98507f2 commit 5750a6a
Showing 1 changed file with 11 additions and 8 deletions.
19 changes: 11 additions & 8 deletions library/core/src/slice/sort.rs
Original file line number Diff line number Diff line change
Expand Up @@ -188,22 +188,25 @@ where
// This binary heap respects the invariant `parent >= child`.
let mut sift_down = |v: &mut [T], mut node| {
loop {
// Children of `node`:
let left = 2 * node + 1;
let right = 2 * node + 2;
// Children of `node`.
let mut child = 2 * node + 1;
if child >= v.len() {
break;
}

// Choose the greater child.
let greater =
if right < v.len() && is_less(&v[left], &v[right]) { right } else { left };
if child + 1 < v.len() && is_less(&v[child], &v[child + 1]) {
child += 1;
}

// Stop if the invariant holds at `node`.
if greater >= v.len() || !is_less(&v[node], &v[greater]) {
if !is_less(&v[node], &v[child]) {
break;
}

// Swap `node` with the greater child, move one step down, and continue sifting.
v.swap(node, greater);
node = greater;
v.swap(node, child);
node = child;
}
};

Expand Down

0 comments on commit 5750a6a

Please sign in to comment.