Rust每日一练(Leetday0015) 字符串相乘、通配符匹配、跳跃游戏II

简介: Rust每日一练(Leetday0015) 字符串相乘、通配符匹配、跳跃游戏II

43. 字符串相乘 Multiply Strings

给定两个以字符串形式表示的非负整数 num1num2,返回 num1num2 的乘积,它们的乘积也表示为字符串形式。

注意:不能使用任何内置的 BigInteger 库或直接将输入转换为整数。

示例 1:

输入: num1 = "2", num2 = "3"

输出: "6"

示例 2:

输入: num1 = "123", num2 = "456"

输出: "56088"


提示:

  • 1 <= num1.length, num2.length <= 200
  • num1num2 只能由数字组成。
  • num1num2 都不包含任何前导零,除了数字0本身。

代码:

fn multiply(num1: String, num2: String) -> String {
    if num1 == "0" || num2 == "0" {
        return String::from("0");
    }
    let (m, n) = (num1.len(), num2.len());
    let mut ans_arr: Vec<i32> = vec![0; m+n];
    let num1_bytes = num1.as_bytes();
    let num2_bytes = num2.as_bytes();
    for i in (0..m).rev() {
        let x = (num1_bytes[i] - b'0') as i32;
        for j in (0..n).rev() {
            let y = (num2_bytes[j] - b'0') as i32;
            ans_arr[i + j + 1] += x * y;
        }
    }
    for i in (1..m+n).rev() {
        ans_arr[i - 1] += ans_arr[i] / 10;
        ans_arr[i] %= 10;
    }
    let mut idx = 0;
    while idx < m+n && ans_arr[idx] == 0 {
        idx += 1;
    }
    let ans_bytes: Vec<u8> = ans_arr[idx..].iter().map(|x| (*x as u8) + b'0').collect();
    String::from_utf8(ans_bytes).unwrap()
}
fn main() {
    println!("{}", multiply(String::from("123"), String::from("456")));
}

输出:

56088


44. 通配符匹配 Wildcard Matching

给定一个字符串 (s) 和一个字符模式 (p) ,实现一个支持 '?''*' 的通配符匹配。

'?' 可以匹配任何单个字符。

'*' 可以匹配任意字符串(包括空字符串)。


两个字符串完全匹配才算匹配成功。

说明:

  • s 可能为空,且只包含从 a-z 的小写字母。
  • p 可能为空,且只包含从 a-z 的小写字母,以及字符 ?*

示例 1:

输入:

s = "aa"

p = "a"

输出: false

解释: "a" 无法匹配 "aa" 整个字符串。

示例 2:

输入:

s = "aa"

p = "*"

输出: true

解释: '*' 可以匹配任意字符串。


示例 3:

输入:

s = "cb"

p = "?a"

输出: false

解释: '?' 可以匹配 'c', 但第二个 'a' 无法匹配 'b'。


示例 4:

输入:

s = "adceb"

p = "*a*b"

输出: true

解释: 第一个 '*' 可以匹配空字符串, 第二个 '*' 可以匹配字符串 "dce".


示例 5:

输入:

s = "acdcb"

p = "a*c?b"

输出: false


代码:

fn is_match(s: &str, p: &str) -> bool {
    let (mut si, mut pi) = (0, 0);
    let (mut s_si, mut p_si) = (0, 0);
    let s_bytes = s.as_bytes();
    let p_bytes = p.as_bytes();
    while si < s_bytes.len() {
        if pi < p_bytes.len() && (s_bytes[si] == p_bytes[pi] || p_bytes[pi] == b'?') {
            si += 1;
            pi += 1;
        } else if pi < p_bytes.len() && p_bytes[pi] == b'*' {
            s_si = si;
            p_si = pi;
            pi += 1;
        } else if p_si == usize::MAX {
            return false;
        } else {
            s_si += 1;
            si = s_si;
            pi = p_si + 1;
        }
    }
    while pi < p_bytes.len() && p_bytes[pi] == b'*' {
        pi += 1;
    }
    pi == p_bytes.len()
}
fn main() {
    println!("{}", is_match("aa", "*"));
    println!("{}", is_match("adceb", "*a*b"));
    println!("{}", is_match("acdcd", "a*c?b"));
}

输出:

true

true

false


45. 跳跃游戏 II Jump Game II

给你一个非负整数数组 nums ,你最初位于数组的第一个位置。

数组中的每个元素代表你在该位置可以跳跃的最大长度。

你的目标是使用最少的跳跃次数到达数组的最后一个位置。

假设你总是可以到达数组的最后一个位置。

示例 1:

输入: nums = [2,3,1,1,4]

输出: 2

解释: 跳到最后一个位置的最小跳跃数是 2。

    从下标为 0 跳到下标为 1 的位置,跳 1 步,然后跳 3 步到达数组的最后一个位置。


示例 2:

输入: nums = [2,3,0,1,4]

输出: 2


提示:

  • 1 <= nums.length <= 10^4
  • 0 <= nums[i] <= 1000

代码:

fn jump(nums: Vec<i32>) -> i32 {
    let (mut end, mut max_pos, mut steps) = (0, 0, 0);
    for i in 0..nums.len()-1 {
        max_pos = max(max_pos, i + nums[i] as usize);
        if i == end {
            end = max_pos;
            steps += 1;
        }
    }
    steps
}
fn max(a: usize, b: usize) -> usize {
    if a > b {
        a
    } else {
        b
    }
}
fn main() {
    println!("{}", jump(vec![2, 3, 1, 1, 4]));
    println!("{}", jump(vec![2, 3, 0, 1, 4]));
}

输出:

2

2


🌟每日一练刷题专栏🌟

持续,努力奋斗做强刷题搬运工!

👍 点赞,你的认可是我坚持的动力!

🌟 收藏,你的青睐是我努力的方向!

评论,你的意见是我进步的财富!  

主页:https://hannyang.blog.csdn.net/

Rust每日一练 专栏

(2023.5.16~)更新中...

Golang每日一练 专栏

(2023.3.11~)更新中...

Python每日一练 专栏

(2023.2.18~2023.5.18)暂停更

C/C++每日一练 专栏

(2023.2.18~2023.5.18)暂停更

Java每日一练 专栏

(2023.3.11~2023.5.18)暂停更


目录
相关文章
|
存储 Rust 程序员
Rust中数据类型详解:从整数到字符串
本文将详细解析Rust编程语言中的基本数据类型,包括整数、浮点数、布尔值、字符与字符串。我们将深入探讨每种数据类型的特性、使用场景以及它们在Rust中的实现方式,帮助读者更好地理解和应用这些基础元素。
|
Rust 编译器 开发者
Cargo:Rust的神秘助手,它将如何改变包管理游戏规则?
【8月更文挑战第31天】Rust的包管理器Cargo简化了依赖管理和构建过程,与编译器无缝集成,提供从依赖下载到编译构建的全套解决方案。通过`cargo new`创建项目后,编辑`Cargo.toml`文件即可轻松管理依赖。Cargo还支持自动生成文档、运行测试及发布代码,并通过`crates.io`平台方便查找和分享Rust库,是Rust生态系统中的重要工具,有助于提升开发者生产力。
262 1
|
算法 索引 Python
【Leetcode刷题Python】55. 跳跃游戏
解决LeetCode "跳跃游戏"问题的Python实现代码,使用了贪心算法的思路。代码中初始化最远可到达位置 max_k,并遍历数组 nums,通过更新 max_k 来记录每次能跳到的最远位置,如果在任何时刻 max_k 大于或等于数组的最后一个索引,则返回 True,表示可以到达数组的末尾;如果当前索引 i 超出了 max_k,则返回 False,表示无法继续前进。时间复杂度为 O(n),空间复杂度为 O(1)。
177 1
|
存储 Rust 安全
30天拿下Rust之字符串
在Rust中,字符串是一种非常重要的数据类型,用于处理文本数据。Rust的字符串是以UTF-8编码的字节序列,主要有两种类型:&str和String。其中,&str是一个对字符数据的不可变引用,更像是对现有字符串数据的“视图”,而String则是一个独立、可变更的字符串实体。
163 0
|
机器学习/深度学习 存储 算法
Python5种算法回溯+剪枝、字典序、递归交换、计数回溯、迭代法 实现全排列ll【力扣题47】
Python5种算法回溯+剪枝、字典序、递归交换、计数回溯、迭代法 实现全排列ll【力扣题47】
|
Python
【Leetcode刷题Python】46. 全排列
本文介绍了LeetCode题目46的Python编程解决方案,题目要求给定一个不含重复数字的数组,返回该数组所有可能的全排列。
157 0
|
Python 人工智能
讯飞星火、文心一言和通义千问同时编“贪吃蛇”游戏,谁会胜出?
讯飞星火、文心一言和通义千问同时编“贪吃蛇”游戏,谁会胜出?
354 1
讯飞星火、文心一言和通义千问同时编“贪吃蛇”游戏,谁会胜出?
|
Rust 安全
Rust猜数字游戏
Rust猜数字游戏
160 0
|
存储 移动开发 Rust
【Rust学习】02_猜谜游戏
让我们一起动手完成一个项目,来快速上手 Rust!本章将介绍 Rust 中一些常用概念,并向您展示如何在实际项目中运用它们。您将会学到 let、match、方法、关联函数、引用外部 crate 等知识!后续章节会深入探讨这些概念的细节。
180 0
|
存储 机器学习/深度学习 算法
python 3种算法 回溯法、字典序生成、递归交换 实现全排列【力扣46题】
python 3种算法 回溯法、字典序生成、递归交换 实现全排列【力扣46题】

推荐镜像

更多