Rust——leetcode 677. 键值映射

use std::collections::HashMap;
use std::rc::Rc;
use std::cell::RefCell;

// 节点定义
struct Node {
    value: i32,
    next: HashMap<char, Rc<RefCell<Node>>>,
}

impl Node {
    pub fn new() -> Self {
        return Self {
            value: 0,
            next: HashMap::new(),
        };
    }
}

struct MapSum {
    root: Rc<RefCell<Node>>,
}


/**
 * `&self` means the method takes an immutable reference.
 * If you need a mutable reference, change it to `&mut self` instead.
 */
impl MapSum {
    /** Initialize your data structure here. */
    fn new() -> Self {
        return MapSum {
            root: Rc::new(RefCell::new(Node::new())),
        };
    }

    fn insert(&self, key: String, val: i32) {
        let mut tmp = self.root.clone();
        // 遍历单词
        for c in key.chars() {
            let n = tmp.borrow().next.get(&c).cloned();
            if let Some(no) = n {
                tmp = no.clone();
            } else {
                let t = Rc::new(RefCell::new(Node::new()));
                tmp.borrow_mut().next.insert(c, t.clone());
                tmp = t.clone()
            };
        }
        tmp.borrow_mut().value = val;
    }

    fn sum(&self, prefix: String) -> i32 {
        let mut tmp = self.root.clone();
        for c in prefix.chars() {
            let n = tmp.borrow().next.get(&c).cloned();
            if let Some(no) = n {
                tmp = no.clone();
            } else {
                return 0;
            };
        }

        return self.recursion_sum(tmp);
    }

    fn recursion_sum(&self, node: Rc<RefCell<Node>>) -> i32 {
        let mut res = node.borrow().value;
        for (_k, v) in node.borrow().next.iter() {
            res += self.recursion_sum(v.clone())
        }

        return res;
    }
}


结果

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Rust 中解析 .eml(电子邮件)文件通常涉及到读取二进制数据并使用库来解析电子邮件的结构。Rust 有一个名为 `EmailParser` 的库,它可以帮助你处理这个任务。以下是一个简单的步骤指南: 1. **添加依赖库**: 首先,你需要在你的 `Cargo.toml` 文件中添加 `email-lexer` 和 `email-parser` 作为依赖。例如: ```toml [dependencies] email-lexer = "0.16" email-parser = "0.16" ``` 2. **导入和使用库**: 在你的 Rust 代码中,引入这些库并创建一个 `EmailParser` 的实例: ```rust extern crate email; extern crate email_lexical; use std::fs::File; use std::io::{BufReader, BufRead}; use email::parser::Parser; use email_lexical::reader::Reader; ``` 3. **读取和解析文件**: 打开并读取 .eml 文件的内容,然后用 `EmailParser` 解析: ```rust async fn parse_email(file_path: &str) -> Result<email::Message, Box<dyn std::error::Error>> { let file = File::open(file_path)?; let reader = BufReader::new(file); let mut email_reader = Reader::new(reader); Parser::parse_message(email_reader) .await .map(|msg| msg.unwrap()) .map_err(|err| Box::new(err)) // 将错误转换为 `Box<dyn std::error::Error>` } ``` 4. **处理解析结果**: 获取到 `email::Message` 对象后,你可以遍历邮件头和正文,提取所需的信息: ```rust async fn main() { let file_path = "path/to/your/email.eml"; let message = parse_email(&file_path).await?; // ... 进行邮件内容的处理,如打印头信息或正文 println!("Subject: {}", message.headers().get("Subject").unwrap_or_default()); println!("Body: {}", message.body_text().unwrap_or_default()); } ``` **相关问题--:** 1. 如何处理解析 .eml 文件时可能出现的错误? 2. `email::Message` 结构体提供了哪些常用的方法来访问邮件内容? 3. Rust 中如何处理异步 I/O,以便在解析大文件时避免阻塞?

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值