quickselect

基于rust的选择算法

4 releases

0.1.3 Feb 21, 2024
0.1.2 May 26, 2022
0.1.1 May 24, 2022
0.1.0 May 24, 2022

BSD-3-Clause

6KB
109 lines

quickselect

基于rust的选择算法。

API

pub fn quick_select(
    arr: &mut Vec<f64>, 
    k: usize, 
    left: usize, 
    right: usize, 
    is_left_smallest: bool
)
  • arr: 可变向量引用,该算法会对向量顺序修改。
  • k:用于部分排序的中间索引。
  • left: 排序起止索引,通常是0。
  • right:排序终止索引,通常是arr.len()-1。
  • is_left_smallest: true时,[left,k]是[left,right]中前k项最小的值;false时,[left,k]是[left,right]中前k项最大的值。

示例

  let mut arr_f64 = vec![
            65.0, 28.0, 59.0, 33.0, 21.0, 56.0, 22.0, 95.0, 50.0, 12.0, 90.0, 53.0, 28.0, 77.0,
            39.0,
        ];
        let length = arr_f64.len();
        quick_select(&mut arr_f64, 8, 0, length - 1, true);
        assert_eq!(
            arr_f64,
            vec![
                39.0, 28.0, 28.0, 33.0, 21.0, 12.0, 22.0, 50.0, 53.0, 56.0, 59.0, 65.0, 90.0, 77.0,
                95.0
            ]
        );

实际作用

常用于求数组中前k项最大、最小值。

No runtime deps