[lc-rs] swap|lev_dist源码

lev_dist源码

(没想到在这种时候,编译器还在守护我(╥﹏╥),rustc,你真的)

用于 typo 检查和拼写错误时的候选词的建议。

在 Rust 源码文件夹的 compiler/rustc_span/src/lev_distance.rs。

edit_distance 算法的应用演示:

lvy rust$ rustup dog

: The subcommand 'dog' wasn't recognized

Did you mean 'doc'?

如上所示,输入 rustup dog 时,rustup 不存在 dog 这个子命令,但是它会挨个遍历候选词中最接近的一个词。

最后建议把 dog 改成 doc ,因为 dog 和 doc 之间 edit_distance 最小。

工程项目中可以用 strsim 库提供的 edit_distance 算法,例如过程宏库 darling 和 async-graphql 都用到了 strsim 库


/// https://github.com/rust-lang/rust/blob/master/compiler/rustc_span/src/lev_distance.rs

fn lev_distance(a: &str, b: &str) -> usize {

// cases which don't require further computation

if a.is_empty() {

return b.chars().count();

} else if b.is_empty() {

return a.chars().count();

}

let mut dcol: Vec<_> = (0..=b.len()).collect();

let mut t_last = 0;

for (i, sc) in a.chars().enumerate() {

let mut current = i;

dcol0 = current + 1;

for (j, tc) in b.chars().enumerate() {

let next = dcolj + 1;

if sc == tc {

dcolj + 1 = current;

} else {

dcolj + 1 = std::cmp::min(current, next);

dcolj + 1 = std::cmp::min(dcolj + 1, dcolj) + 1;

}

current = next;

t_last = j;

}

}

dcolt_last + 1

}

lc66

impl Solution {

pub fn plus_one(mut digits: Vec<i32>) -> Vec<i32> {

for d in digits.iter_mut().rev() {

if *d < 9 {

*d += 1; // 进位

return digits;

}

*d = 0; // 进位数字的右边数字都变成 0

}

// digits 全是 9,加一后变成 100...00

digits.push(0);

digits0 = 1;

digits

}

}

lc53

3步,前缀和+贪心

impl Solution {

pub fn max_sub_array(nums: Vec<i32>) -> i32 {

let mut ans = i32::MIN;

let mut min_pre_sum = 0;

let mut pre_sum = 0;

for x in nums {

pre_sum += x; // 当前的前缀和

ans = ans.max(pre_sum - min_pre_sum); // 减去前缀和的最小值

min_pre_sum = min_pre_sum.min(pre_sum); // 维护前缀和的最小值

}

ans

}

}

lc46

利用swap,swap真是个数组的原子操作!熟练掌握swap的使用几乎能完全所有数组的原地变换🥺

pub fn per(v: &mut Vec<i32>, idx: usize, res: &mut Vec<Vec<i32>>) {

if idx == v.len() {

res.push(v.clone());

return;

}

for i in idx..v.len() {

unsafe { std::ptr::swap(&mut vidx, &mut vi); }

per(v, idx + 1, res);

unsafe { std::ptr::swap(&mut vi, &mut vidx); }

}

}

impl Solution {

pub fn permute(mut nums: Vec<i32>) -> Vec<Vec<i32>> {

let len = (2..=nums.len()).product();

let mut res = Vec::with_capacity(len);

per(&mut nums, 0, &mut res);

res

}

}

相关推荐
Rust研习社1 天前
组合真的优于继承吗?为什么 Rust 和 Go 都拥抱组合舍弃继承?
后端·rust·编程语言
红尘散仙2 天前
想写一个像样的终端 App?试试把 React 的开发体验搬进 Rust TUI
前端·rust
vivo互联网技术2 天前
从 Web 到桌面:基于 Tauri 2.0 + Vue 3 打造 vivo 线下门店「大头贴」拍照体验系统
前端·rust
Rust研习社2 天前
这 8 个 Rust 学习资源值得每个新手收藏起来
后端·rust·编程语言
星栈3 天前
10 分钟跑起第一个 Dioxus 应用:`dx` CLI、`rsx!` 和热更新好不好用
前端·rust·前端框架
望眼欲穿的程序猿3 天前
读取芯片内部温度传感器
嵌入式硬件·rust
望眼欲穿的程序猿3 天前
ADC 模拟电压采集
嵌入式硬件·rust
codexu_4612291873 天前
NoteGen 里一条记录如何变成 Markdown
前端·笔记·rust·tauri
Rust研习社3 天前
Rust 错误处理的黄金搭档:一个定义错误,一个传播错误
后端·rust·编程语言
techdashen3 天前
绕过系统 ICMP:用 rawsock、Npcap 和 WMI 找到默认网卡
开发语言·arm开发·rust