让人抓狂的 Rust

本贴最后更新于 1787 天前,其中的信息可能已经斗转星移

刚看 Rust 没几天,想着去 leetcode 上练练,找到这么一个题

80. 删除排序数组中的重复项 II

答案很简单,Java 代码答案如下

 

class Solution { public int removeDuplicates(int[] nums) { int i = 0; for (int n : nums) if (i < 2 || n > nums[i-2]) nums[i++] = n; return i; } }

很简单吧,也看了几天 Rust 语法了,直接上

fn remove_duplicates(nums: μ Vec<i32>) -> i32 { let mut i = 0; for x in nums { if i < 2 || x > nums[i-2] { nums[i] = x; } i++; } return i; }

这也太简单了,然而。。。

$ cargo run 101 ↵ Compiling demo v0.1.0 (/Users/tiangaoshi/rust/demo) error: expected expression, found `+` --> src/main.rs:14:11 | 14 | i++; | ^ expected expression error[E0308]: mismatched types --> src/main.rs:11:25 | 11 | if i < 2 || x > nums[i-2] { | ^^^^^^^^^ | | | expected `μ i32`, found `i32` | help: consider mutably borrowing here: `μ nums[i-2]` error[E0308]: mismatched types --> src/main.rs:12:23 | 12 | nums[i] = x; | ^ | | | expected `i32`, found `μ i32` | help: consider dereferencing the borrow: `*x` error[E0308]: mismatched types --> src/main.rs:16:12 | 8 | fn remove_duplicates(nums: μ Vec<i32>) -> i32 { | --- expected `i32` because of return type ... 16 | return i; | ^ expected `i32`, found `usize` | help: you can convert an `usize` to `i32` and panic if the converted value wouldn't fit | 16 | return i.try_into().unwrap(); | ^^^^^^^^^^^^^^^^^^^^^

WTF??? 这么多错误, let mut 不是变量吗,nums 不是数组吗,为啥?

没办法,碰到问题解决问题,

第一个最简单,不支持 ++, 那就 i += 1;

第二个没看懂啥意思,大概是不可变,加一行 let a = i - 2;

第三个有提示了 nums[i] = *x;

最后一个应该是类型错误

fn remove_duplicates(nums: μ Vec<i32>) -> i32 { let mut i = 0; for x in nums { let a = i - 2; if i < 2 || *x > nums[a] { nums[i] = *x; } i += 1; } return i as i32; }

gogogo~~~~

╰─$ cargo run 101 ↵ Compiling demo v0.1.0 (/Users/tiangaoshi/rust/demo) error[E0382]: borrow of moved value: `nums` --> src/main.rs:12:26 | 8 | fn remove_duplicates(nums: μ Vec<i32>) -> i32 { | ---- move occurs because `nums` has type `μ std::vec::Vec<i32>`, which does not implement the `Copy` trait 9 | let mut i = 0; 10 | for x in nums { | ---- | | | value moved here | help: consider borrowing to avoid moving into the for loop: `#` 11 | let a = i - 2; 12 | if i < 2 || *x > nums[a] { | ^^^^ value borrowed here after move error: aborting due to previous error

我真是黑人问号脸了,什么鬼啊


此处省去几天时间的各种尝试和查阅文档,

甚至仔仔细细读了 <<Rust 编程之道 >> 前面几章,

中间还找到了一个仓库 https://github.com/aylei/leetcode-rust ,直接去翻 80

https://github.com/aylei/leetcode-rust/blob/master/src/solution/s0080_remove_duplicates_from_sorted_array_ii.rs

oh shit~
 

今天综合几天的经验,终于尝试搞出了一个能过的版本

fn remove_duplicates(nums: μ Vec<i32>) -> i32 { let mut i = 0; let list = nums.clone(); for x in list { if i < 2 { let a = i; nums[a] = x; i += 1; } else { let a = i; let b = i - 2; if x > nums[b] { nums[a] = x; i += 1; } } } return i as i32; }

我真的是醉了,这是个什么鬼语言,好歹我也是写过 C 玩过汇编单片机,C++ 入过门,N 年 Java, 一年 Golang 滚过, Kotlin 爽过,中间还掺杂 Elixir Swift 认知的职业搬砖工,这写第一个算法题就玩我这么久,坑啊

只能说自己菜了,果然老人言说得对,一上来就写代码肯定会栽跟头的

Rust 肯定是值得学习的,看看人家 actix,简直是一骑绝尘

学无止境,目测最最后一版也只是能过而已,肯定有更精炼的写法,手动捂脸,🤦🤦🤦

最后附上一个此题的提交记录,同一套算法

图片.png

第二天

感觉好像又理解了些东西,又写了一版,好看多了,舒服

impl Solution { fn remove_duplicates(nums: μ Vec<i32>) -> i32 { let mut ans = 2; let size = nums.len(); for i in 2..size { let a = ans - 2; if nums[a] < nums[i] { nums[ans] = nums[i]; ans += 1; } } return ans as i32; } }

觉得学语言其实是在学模式,解决一个问题有千万种方法,不通的方法对应的也是不通的效率,开发效率跟运行效率就像鱼跟熊掌,enmmm,小孩子才做选择,我都要

  • Rust

    Rust 是一门赋予每个人构建可靠且高效软件能力的语言。Rust 由 Mozilla 开发,最早发布于 2014 年 9 月。

    58 引用 • 22 回帖 • 2 关注
  • LeetCode

    LeetCode(力扣)是一个全球极客挚爱的高质量技术成长平台,想要学习和提升专业能力从这里开始,充足技术干货等你来啃,轻松拿下 Dream Offer!

    209 引用 • 72 回帖 • 1 关注
2 操作
tiangao 在 2020-04-21 10:59:32 更新了该帖
tiangao 在 2020-04-21 10:55:14 更新了该帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • hefeng

    Rust 性能这么好的么?

    1 回复
  • tiangao via macOS

    毕竟目标是 C++

  • itfanr

    如果 rust 代码能编译通过,基本没有崩溃的可能。

推荐标签 标签

  • Ngui

    Ngui 是一个 GUI 的排版显示引擎和跨平台的 GUI 应用程序开发框架,基于
    Node.js / OpenGL。目标是在此基础上开发 GUI 应用程序可拥有开发 WEB 应用般简单与速度同时兼顾 Native 应用程序的性能与体验。

    7 引用 • 9 回帖 • 397 关注
  • 30Seconds

    📙 前端知识精选集,包含 HTML、CSS、JavaScript、React、Node、安全等方面,每天仅需 30 秒。

    • 精选常见面试题,帮助您准备下一次面试
    • 精选常见交互,帮助您拥有简洁酷炫的站点
    • 精选有用的 React 片段,帮助你获取最佳实践
    • 精选常见代码集,帮助您提高打码效率
    • 整理前端界的最新资讯,邀您一同探索新世界
    488 引用 • 384 回帖 • 3 关注
  • JVM

    JVM(Java Virtual Machine)Java 虚拟机是一个微型操作系统,有自己的硬件构架体系,还有相应的指令系统。能够识别 Java 独特的 .class 文件(字节码),能够将这些文件中的信息读取出来,使得 Java 程序只需要生成 Java 虚拟机上的字节码后就能在不同操作系统平台上进行运行。

    180 引用 • 120 回帖
  • Kubernetes

    Kubernetes 是 Google 开源的一个容器编排引擎,它支持自动化部署、大规模可伸缩、应用容器化管理。

    116 引用 • 54 回帖
  • 浅吟主题

    Jeffrey Chen 制作的思源笔记主题,项目仓库:https://github.com/TCOTC/Whisper

    1 引用 • 28 回帖
  • Anytype
    3 引用 • 31 回帖 • 14 关注
  • PHP

    PHP(Hypertext Preprocessor)是一种开源脚本语言。语法吸收了 C 语言、 Java 和 Perl 的特点,主要适用于 Web 开发领域,据说是世界上最好的编程语言。

    179 引用 • 408 回帖 • 486 关注
  • Vim

    Vim 是类 UNIX 系统文本编辑器 Vi 的加强版本,加入了更多特性来帮助编辑源代码。Vim 的部分增强功能包括文件比较(vimdiff)、语法高亮、全面的帮助系统、本地脚本(Vimscript)和便于选择的可视化模式。

    29 引用 • 66 回帖
  • Lute

    Lute 是一款结构化的 Markdown 引擎,支持 Go 和 JavaScript。

    27 引用 • 196 回帖 • 27 关注
  • 反馈

    Communication channel for makers and users.

    124 引用 • 928 回帖 • 267 关注
  • 数据库

    据说 99% 的性能瓶颈都在数据库。

    345 引用 • 724 回帖 • 1 关注
  • 工具

    子曰:“工欲善其事,必先利其器。”

    295 引用 • 749 回帖
  • abitmean

    有点意思就行了

    29 关注
  • Wide

    Wide 是一款基于 Web 的 Go 语言 IDE。通过浏览器就可以进行 Go 开发,并有代码自动完成、查看表达式、编译反馈、Lint、实时结果输出等功能。

    欢迎访问我们运维的实例: https://wide.b3log.org

    30 引用 • 218 回帖 • 640 关注
  • 一些有用的避坑指南。

    69 引用 • 93 回帖
  • Rust

    Rust 是一门赋予每个人构建可靠且高效软件能力的语言。Rust 由 Mozilla 开发,最早发布于 2014 年 9 月。

    58 引用 • 22 回帖 • 2 关注
  • 黑曜石

    黑曜石是一款强大的知识库工具,支持本地 Markdown 文件编辑,支持双向链接和关系图。

    A second brain, for you, forever.

    21 引用 • 196 回帖
  • 域名

    域名(Domain Name),简称域名、网域,是由一串用点分隔的名字组成的 Internet 上某一台计算机或计算机组的名称,用于在数据传输时标识计算机的电子方位(有时也指地理位置)。

    43 引用 • 208 回帖 • 1 关注
  • 阿里云

    阿里云是阿里巴巴集团旗下公司,是全球领先的云计算及人工智能科技公司。提供云服务器、云数据库、云安全等云计算服务,以及大数据、人工智能服务、精准定制基于场景的行业解决方案。

    84 引用 • 324 回帖
  • 笔记

    好记性不如烂笔头。

    311 引用 • 796 回帖
  • 房星科技

    房星网,我们不和没有钱的程序员谈理想,我们要让程序员又有理想又有钱。我们有雄厚的房地产行业线下资源,遍布昆明全城的 100 家门店、四千地产经纪人是我们坚实的后盾。

    6 引用 • 141 回帖 • 588 关注
  • API

    应用程序编程接口(Application Programming Interface)是一些预先定义的函数,目的是提供应用程序与开发人员基于某软件或硬件得以访问一组例程的能力,而又无需访问源码,或理解内部工作机制的细节。

    78 引用 • 430 回帖
  • Postman

    Postman 是一款简单好用的 HTTP API 调试工具。

    4 引用 • 3 回帖 • 4 关注
  • Java

    Java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的。Java 技术具有卓越的通用性、高效性、平台移植性和安全性。

    3194 引用 • 8214 回帖
  • App

    App(应用程序,Application 的缩写)一般指手机软件。

    91 引用 • 384 回帖
  • Swagger

    Swagger 是一款非常流行的 API 开发工具,它遵循 OpenAPI Specification(这是一种通用的、和编程语言无关的 API 描述规范)。Swagger 贯穿整个 API 生命周期,如 API 的设计、编写文档、测试和部署。

    26 引用 • 35 回帖 • 1 关注
  • TextBundle

    TextBundle 文件格式旨在应用程序之间交换 Markdown 或 Fountain 之类的纯文本文件时,提供更无缝的用户体验。

    1 引用 • 2 回帖 • 73 关注