用 rust 写算法

冒泡排序

use std::io::*;

fn main() {
    let mut str_buf = String::new();
    stdin().read_line(&mut str_buf).expect("failed to read");
    str_buf.clear();
    stdin().read_line(&mut str_buf).expect("failed to read");
    let num_arr: Vec<i32> = str_buf
        .trim()
        .split_whitespace()
        .into_iter()
        .map(|s| s.parse().unwrap())
        .collect();
    let arr_inc = bubble_sort(&num_arr, |a, b| a > b);
    arr_inc.iter().for_each(|e| print!("{} ", e));
    println!();
    let arr_dec = bubble_sort(&num_arr, |a, b| a < b);
    arr_dec.iter().for_each(|e| print!("{} ", e));
    println!();
}

fn bubble_sort(input: &Vec<i32>, cmp: fn(a: i32, b: i32) -> bool) -> Vec<i32> {
    let mut sorting_arr = input.clone();
    let n = sorting_arr.len();
    for i in 0..n {
        for j in 0..n-i-1 {
            if cmp(sorting_arr[j], sorting_arr[j+1]) {
                let tmp = sorting_arr[j];
                sorting_arr[j] = sorting_arr[j+1];
                sorting_arr[j+1] = tmp;               
            }
        }
    }
    sorting_arr
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值