刷LeetCode的正确姿势——第1、125题

  最近刷LeetCode比较频繁,就购买了官方的参考电子书 (CleanCodeHandbook),里面有题目的解析和范例源代码,可以省去非常多寻找免费经验分享内容和整理这些资料的时间。惊喜的是,里面的所有源代码都是用java语言写的。

  接下来的一段时间里,我会将里面的大部分内容翻译成中文,再加上一些小y自己的解法和扩展内容,以博客的形式发在博客园。我想,这会是一件非常有趣的事情。

  以下是翻译的前言部分,第1、4题以及其解析部分。



前言:

  嗨,各位刷LeetCode的小伙伴们。

  就像你们看到这本书的书名,这是一本教人如何在面对面试题时写出简洁代码的指导手册。  

  你将会学习到如何写出优雅的代码,帮助你顺利地通过各种各样的技术面试。这本电子书将会在你上LeetCode刷题时带来最好的帮助。

  本书中,每一道题目都会有一个“Code it now”的链接。点击这个链接,将会打开OJ题目的页面。用户可以在这个OJ系统上提交自己的代码,并且即时得到反馈,知道给出的答案正确与否。如果在点击“Code it now”之后看到“Coming soon”的提示,那就是这个问题将会在不久的将来被添加进来,敬请期待。

  每道题都会注明难度和出现频率。有三种难度等级:简单(Easy),中等(Medium),困难(Hard)。简单难度的题目是那些很容易想到思路,而且实现起来也相当直接的问题。大多数面试中会遇到的问题都是这种类型的。

  另一方面,困难难度的题目大多数是算法类型的,需要你在动手写代码之前有更多的思考。LeetCode上有一些这类型的题目,但并不多。

  另外,还有三种出现频率的等级:低,中等,高。这里的频率指的是在面试中会遇到此问题或类似问题的频繁程度,数据来源于用户调查:“你是否曾经在一次面试中遇到过这道题目?”通过频率,我们可以大概知道有多大可能会在面试中遇到同样或类似的题目。

  每一道题目都可能会有“你在面试的时候可以这样问”(Example Questions Candidate Might Ask),举例说明你在遇到这道时应该问面试官些什么。弄清楚问题的限制条件是非常重要的,而且这是一个很好的缕清思路的过程。

  每一个问题都会有数不清的解决思路。每一个解决思路都会有一个时间复杂度和空间复杂度,这是两个你在选择哪一个思路时应该考虑的关键因素。在真正开始构建解决方案时,你应该首先分析的是跑这个程序要花多长的时间,和要占用多少的内存空间。在技术面试当中,分析时间复杂度和空间复杂度是非常常见的,每一个面试者都应该好好准备。

  独立解决一个问题是最好的学习途径。如果你被某一个地方卡住了,本书的提示能为你提供一些小TIPS,帮助你打开思路。如果你看完提示之后还是一筹莫展,那就翻到分析部分并且试着在LeetCode OJ上敲出自己实现的代码。

  即便你觉得某一道题很简单,但是写出正确而且整洁的代码并不是像很多人想象的那样简单。举个例子,如果你在某次面试当中为了解一道题写了超过30行的代码,那么很可能是不够简洁的。本书中给出的大部分参考范例代码行数都在20行到30行之间。

第一章:数组和字符串

第1题 两数加和(Tow Sum

Code it now! https://leetcode.com/problems/two-sum/

难度:简单 频率:高

问题描述:
  一个整数数组,找出某两个数加和等于某一个特定的数(target)。

  要求函数twoSum返回符合要求的两数在数组中所处的位置,index1和index2(index1必须小于index2)。请注意,你所编写的函数返回值应该是下标加1.(本题只需要考虑仅有唯一解的情况)。

解题方法:
  O(n2)的时间复杂度,常数空间复杂度-暴力算法(Brute force)
  暴力算法思路非常简单,遍历数组中每个元素x并且试图找到是否有另外一个值相加和等于目标数,即target - x。因为每一次匹配值都需要遍历一次数组剩余元素,所以时间复杂度是n平方。(译者注:原作并未提供暴力算法的代码,以下是我的解法)


  

  O(n)的时间复杂度,n的空间复杂度-哈希表(Hash table)
  通过将数组的值和索引使用哈希表存储起来,我们可以把匹配值的时间复杂度降为1。

(译者注:LeetCode还会在用户提交答案AC之后提供其解法与其他用户解法的量化对比数据)

暴力算法的性能——57ms

哈希表的性能——6ms

第四题 回文(Valid Palindrome)

Code it now! https://leetcode.com/problems/valid-palindrome/

难度:容易 频率:中等

问题描述:
  给出一个字符串,判断其是否一个回文字符串,只考虑字母和数字,而且忽略大小写。
  例如,“A man, a plan, a canal: Panama” 是一个回文字符串,而“race a car”不是一个回文字符串。

  面试者可以会问这样的问题:
  问:空字符串算是回文字符串吗?
  答:在这个问题里,我们将空字符串运定义为回文字符串。

解答方法:
  O(n)时间复杂度,常数空间复杂度
  思路非常简单,有两个“指针”——一个为“头指针”,另一个是“尾指针”。两“指针”相向移动直到移动,跳过所有非字母或非数字的字符。

  如果一个字符串只有非字母和非数字的字符,也是回文字符串,因为空字符串也是回文字符串。

算法性能——9ms



译者的话:

  学了算法到底有没有用?

  以前我觉得没什么用,工作很长一段时间都没有用上。后来刷了LeetCode,在老大交给我的几个任务里都用到了一些,例如这一章译文中提到的哈希表,直接把某个数据筛选环节的运行时间从原来的半个小时缩短到10秒,速度足足提升了将近两百倍。

  算法并不是没有用,而是如果一个程序员不懂算法,在实际的编程中他就想不到用哪个算法比较好,只会一味用暴力算法或者是API自带的函数。我惊喜地发现,如果你开始懂一点算法,知道在什么情景下适用,将会带来超乎想象的好处。

   另一方面,也不要把算法想得那么高深和艰涩,大部分实用的算法都只是20行左右的代码就能实现。

  只要你能鼓起勇气,克服因为未知而产生的恐惧,花一点时间和耐心去学习,将会看到一个完全不一样的世界。

(转发随意,转载请注明作者与博客园原地址)

(我的个人微信公众号:scut_xiaoy,搜索ID或扫描下方二维码添加关注,关注程序员自身成长和互联网时代下的新变化)

时间: 2024-10-15 14:21:27

刷LeetCode的正确姿势——第1、125题的相关文章

用golang刷LeetCode

用golang刷LeetCode 用Go语言刷LeetCode记录,只是为了练习Go语言,能力有限不保证都是最优解,只能在此抛转引玉了. 数据结构和算法 数据结构和算法是程序员的命根子,没了命根子也就没有了尊严. 1. 两数之和 题目描述 力扣(LeetCode)链接 给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标. 你可以假设每种输入只会对应一个答案.但是,你不能重复利用这个数组中同样的元素. 示例: 给定 nums

程序员取悦女朋友的正确姿势---Tips(iOS美容篇)

前言 女孩子都喜欢用美图工具进行图片美容,近来无事时,特意为某人写了个自定义图片滤镜生成器,安装到手机即可完成自定义滤镜渲染照片.app独一无二,虽简亦繁. JH定律:魔镜:最漂亮的女人是你老婆魔镜:程序员不是木头人 核心技术 图片滤镜核心技术的基本思路如下: 核心技术流程 具体流程 1.创建一个图像处理工具类 注:该类实例包括一个图像处理方法,该方法在传入原始图像和一个颜色矩阵后生成一个处理好的图像. @interface JHFeilterManager : NSObject @proper

docker centos rpm离线安装1.8.2及pull的正确姿势

1.离线安装 本次只针对1.8.2版本,所需要的rpm包如下 docker-engine-1.8.2-1.el7.centos.x86_64.rpm(已上传51cto) libcgroup-0.41-8.el7.x86_64.rpm libcgroup-devel-0.41-8.el7.x86_64.rpm libcgroup-pam-0.41-8.el7.x86_64.rpm libcgroup-tools-0.41-8.el7.x86_64.rpm(libcgroup请参考开源镜像库) 简单

初刷LeetCode的感受

自从上个月进入实验室的云安全项目组后,因为要接触到实际的代码,在实验室博士的建议下我们项目组的硕士开始刷LeetCode练习编程能力,保持每周抽空刷几道算法题.虽然刷的不多,到现在一共只刷了不到30题,但在刷题的过程中还是有很多感触的. 实验室的博士建议我们按照题目的难易顺序循序渐进由易到难来刷,我也就照做了.因为前段时间在系统地学Python语言,所以我主要用的是Python语言来做,有的题目也采用了C/C++.Java甚至C#多种语言来尝试.在刷题的过程中,总结了自己的一些问题: 1. 对于

观看学习视频的正确姿势与姿态

开学至今,时时被二柱子逼得走投无路. 痛定思过,目前的自己确实是"三拍",一拍觉得这样那样一定可以胸有成竹,二拍有了点子拿起手术刀就开始实践,三拍无法实现代码拍屁股放弃.啊,我为了二柱子建了好多好多包,想过好多好多条"去北京的路",结果...还是死于基础太烂.也不愿意头悬梁锥刺股.所以呢,那就改进学习方式呗,提高效率. 整个开发过程中,自己犯了一个很大的错误.即是在第五周中途才突然发现,其实代码在整个学习过程中虽说是基础但不是没有它就建不成大楼.而我,白白的把4周的

Node.js中使用redis数据库的正确姿势

Redis是一个常用的Nosql数据库,一般用来代替Memcached做缓存服务,同时它也支持数据的持久化,有着比较广泛的应用场景.在Java中使用redis我们已经比较熟悉了,那么在node.js和koa.js框架中使用Redis的正确姿势是怎样的呢? Redis 是完全开源免费的,遵守BSD协议,是一个高性能的key-value数据库. Redis 与其他 key - value 缓存产品有以下三个特点: * Redis支持数据的持久化,可以将内存中的数据保持在磁盘中,重启的时候可以再次加载

重磅消息!河南省考正确姿势:安心过双节!(推迟后18届毕业生有福!)

重磅消息!河南省考正确姿势:安心过双节!(推迟后18届毕业生有福!) 小可爱们,说想我了没? 肯定想了是吧哈哈 自恋一分钟! 河南省考推迟消息已确定 正确姿势:安心过双节! 各位小伙伴可以愉快的过双节啦! 开心吧! 不信请看:这次小编不骗你啦! 证据

准备刷leetcode!

前段时间才知道了这个刷题的地方,但是现在我连动规还没看完,决定把现在这本<计算机算法设计与分析>大概看完就去刷leetcode. 当然看书的时候也是要刷题的,就先刷着学校的sicily吧,毕竟用着挺习惯的. 恩,看完这本书看数据结构C语言那本. 一定要好好学英语,要不然连题目都看不懂...

在Linux(ubuntu server)上面安装NodeJS的正确姿势

上一篇文章,我介绍了 在Windows中安装NodeJS的正确姿势,这一篇,我们继续来看一下在Linux上面安装和配置NodeJS. 为了保持一致,这里也列举三个方法 第一个方法:通过官网下载安装 https://nodejs.org/en/download/ 这种方式的问题是我们需要自己去找网页,找到链接,然后下载 第二个方法:使用apt工具进行安装 默认情况下,在apt的源中只有比较老的版本(注意,需要先apt-get update) 例如,如果运行apt-get install nodej