张土汪 http://github.com/shawnfan Java{script}代码仔

[1.19.2017] 更新:

2017年1月17日, 陪我征战多年的 2014 MackBookPro i7 3.xGHz 被一杯清水结束了生命,在这里深切缅怀悼念。这个Git Repo是小M陪我一字一句打出来的,有过蹉跎,也有过辉煌,陪我从Day1刷题一直刷到了Day1之中。直至今日,小M记录的代码还在给广大coder带来福利。为了延续小M无私奉献的精神,我将重新在这个repo活跃起来,重整已有的问题,也会尝试总结一些System Design方面的想法,将小M还没有能够达成的梦想实现。

原帖:

先贴一个福利:GitHub - shawnfan/LintCode: Java Solutions to problems on LintCode

然后再慢慢谈刷题的经验。

地点西雅图。

这一场算是彻头彻尾的胜利。归功于一年来的刷题。归功于不输阵的心态。归功于日渐成熟的谈吐。更归功于身边人的支持。等待了一年多,我对这场胜利真的期待了太久。

刷题是漫长的路,身边的人能陪伴你,但是从来无法代替你。我刷的最多的是LintCode; LeetCode其实比LintCode要更加严苛一些,在最终的备战时,可以买他们的会员,专门进到各个公司的单元狂刷一下。Flash Back 一下去年刷题的体验:

第一刷的时候完全不知道为什么要做这些事情,只觉得消耗了很多时间,但总不上道。其实什么都没有太刷出来,基本上就是懒洋洋地做题,看看别人的解答,一轮一轮地打击自己的信心。到头来,也只看了100来道题目吧。

第二刷时,完全是因为有最牛逼的公司递来了橄榄枝。那时我又兴奋又紧张,更多是紧张,因为自己真的是半瓶子醋啊!(说实在的,谁平时会没事一直练刷题呢,都是为了工作,都是需要动力的)这时开始仔细的看LeetCode还有LintCode里面的题目,分等级开始安排时间。面试的时间定在了一个月,还剩三十天!这三十天真实打了鸡血地不停刷题,战斗,总结,然后再上。到结尾的时候,大约有200道题目吧,其中100道是之前已经做过的。

然后,就失败了。

第三刷,是来年,我还在无奈的痛苦中,但也到了春暖花开,各个公司撒网的时候了。这一年Facebook, LinkedIn貌似都不太有动静,Twitter也在暴跌40%的痛苦中。苦苦等待,又来了几个机会,这一次,我没有冲动地定下30天的计划,但是依然充满了鸡血。这一边,仔细讲一讲吧,说说也能算是面经。

1. 把真的想去的公司,稍微排在后面一点,一般的公司,放在前面先去,当然是增加面试经验了。 心态还是要端正的:你想,要是后面的公司全都不要你,那么你去哪,废话,当然是去第一家要你的公司;所以,在这个时候要卯足力气,打好鸡血,做做全面的复习,然后上!

2. 心态要好:成败都是这几个月的家常便饭,失败了再走下一个。成功了也要看清自己的目标不要懈怠(虽然我拿到offer立刻就懈怠,后面的面试全部当做旅游)

3. 刷题要有策略。正所谓磨刀不误砍柴工,不要一味地钻进题目里面刷刷刷,复习复习复习,重点是要能总结! 有时候这种废话听上去一点力度都没有,但是实际情况就是那么简单。 咱们刷刷题就能找到工作的这个时代,远远不到拼智商的程度。 那拼什么?拼耐心和拼谁更加不浆糊。 刷了那么久,到底哪些题目是Tree, 哪些是DP,哪些是明显的坑?如果你到现在还没有总结,那。为。什。么。不。总。结! 不总结自己到底做了什么题目,脑子里就是一团浆糊。面试的时候可紧张了,我们这样的小青年,见到面试官肯定羞射,若不胸有成竹,写出来也是一团浆糊。 所以重中之重,就是要学会总结,学会去反思做过的题目。现在的LeetCode(竟然总结了题目开始卖钱我去!?), LintCode都会给出相应的Tag, 这非常好,就是帮助你把题目归类,分类型去刷。

4. 分类型,一个大块一个大块地去攻克。就这么简单。从简单的String, List, Tree 开始吧。

5. 我当时还是花钱买了LeetCode的那些题目的(羞。。。)因为求胜心切,这点小钱,就几个月,花吧,花吧。 这也是对自己的一种投资,也是一点动力,花了钱嘛,make evey peny count!

但是,有一件事情我要说清楚了:这些题目明明都是我们这些草民玩家通过一次次血淋淋的面试换来的宝贵经验,凭什么LeetCode就要拿过去卖钱... 当然, LeetCode提供的服务是特别好的, 他们的test case更加难,比LintCode要严苛一些(对我们自己好),所以charge一些费用也是应该的。但是,我真的觉得知识不应该被用来贩卖,知识应该共享,而你们网站提供的优质刷题环境,可以用来卖会员,比如说,我买了会员,你给我提供快两三倍的run speed等等。。。。。

一颗热爱Open Source的我,自然会好好‘总结’一把。跟网上大部分的大神不同,我不喜欢把我总结的题目都放在Blog里面,实在是,太难搜索了。

我把我做的所有题目都放在了GitHub上, 用我自己的标记方式,写好了题目梗概,自己在每个阶段的解法,在每个题目文件的最上方,还用中文写了用来Trigger Memory的笔记(别问我为什么用中文写:1. 中文容易提醒自己,母语嘛!2. 我不想让阿三门都跑过来看,虽然,open source吧,我还是稍微给一道语言的隔阂)

话都说到这个份上了,你们自己去不去看,就是你们自己的选择啦。用我的代码没问题,要是转我的代码,麻烦在你们转发的帖子上面贴一条我源代码的链接就好啦。 大约三百来道题目吧,你们在刷Lint或者Leet的时候,可以去我的页面搜索题目的名字。300多道,差不多中等的题目都能涉及到了(我去别跟我说现在题目都500多了,我真不明白,以后还让人怎么活!) GitHub - shawnfan/LintCode: Java Solutions to problems on LintCode

LeetCode, LintCode都很好,但刷题的核心是要有血性,会总结。

我的初衷就是想把自己做过的刷题路分享给还在题海的中国同伴,如果你们在看到那些解答,觉得不对,觉得幼稚的时候,send me a fix and pull request,我会定时接受代码的更新,服务大众嘛!

知乎上的一些文章---leetcode【笔记1】的更多相关文章

  1. ARCGIS知乎上的好文章

    http://zhihu.esrichina.com.cn/?/feature/ArcGISAndroidDevNote ArcGIS知乎上有哪些干货可以推荐? http://zhihu.esrich ...

  2. 在知乎上看到 Web Socket这篇文章讲得确实挺好,从头看到尾都非常形象生动,一口气看完,没有半点模糊,非常不错

    在知乎上看到这篇文章讲得确实挺好,从头看到尾都非常形象生动,一口气看完,没有半点模糊,非常不错,所以推荐给大家,非常值得一读. 作者:Ovear链接:https://www.zhihu.com/que ...

  3. Leetcode 笔记 113 - Path Sum II

    题目链接:Path Sum II | LeetCode OJ Given a binary tree and a sum, find all root-to-leaf paths where each ...

  4. Leetcode 笔记 110 - Balanced Binary Tree

    题目链接:Balanced Binary Tree | LeetCode OJ Given a binary tree, determine if it is height-balanced. For ...

  5. Leetcode 笔记 100 - Same Tree

    题目链接:Same Tree | LeetCode OJ Given two binary trees, write a function to check if they are equal or ...

  6. Leetcode 笔记 99 - Recover Binary Search Tree

    题目链接:Recover Binary Search Tree | LeetCode OJ Two elements of a binary search tree (BST) are swapped ...

  7. Leetcode 笔记 101 - Symmetric Tree

    题目链接:Symmetric Tree | LeetCode OJ Given a binary tree, check whether it is a mirror of itself (ie, s ...

  8. Leetcode 笔记 36 - Sudoku Solver

    题目链接:Sudoku Solver | LeetCode OJ Write a program to solve a Sudoku puzzle by filling the empty cells ...

  9. Leetcode 笔记 35 - Valid Soduko

    题目链接:Valid Sudoku | LeetCode OJ Determine if a Sudoku is valid, according to: Sudoku Puzzles - The R ...

随机推荐

  1. ecshop里提出来的js常用函数

    目录 Utils.js jquery.listTable.js 使用例子: ecshop里提出来的js常用函数 Utils.js /* $Id : utils.js 5052 2007-02-03 1 ...

  2. HDU - 5017 Ellipsoid(模拟退火)

    题意 给一个三维椭球面,求球面上距离原点最近的点.输出这个距离. 题解 模拟退火. 把\(z = f(x, y)\)函数写出来,这样通过随机抖动\(x\)和\(y\)坐标就能求出\(z\). 代码 / ...

  3. 51NOD 1128正整数分组V2 二分答案

    这道题是典型的二分答案法.但是首先难道这道题的时候我进行了一系列的思考,甚至联想到了之前多校中类似于树状划分的问题...原因是大家都包括N各节点K个输入.. 实际上最开始联想到了应当使用二分法“枚举” ...

  4. 图学java基础篇之集合

    (本文部分图片引用自其他博客,最后有链接,侵删.由于笔记使用markdown记录,格式可能不是太好看,见谅) 集合结构 红字为java.util包下的,绿字为concurrent包下扩展的与并发相关的 ...

  5. 线段树[To be continued]

    目录 数据结构--线段树 一.定义 二.性质 三.基本操作 0.结构体 1.建树 2.单点查询 3.单点修改 4.区间修改 5.区间查询 四.题目 单点修改.区域查询模板 五.鸣谢 学姐的Blog 百 ...

  6. How to check if Visual Studio 2005 SP1 is installed

    How to check if Visual Studio 2005 SP1 is installed Check the following registry key. HKEY_LOCAL_MAC ...

  7. Hyper-V 网络虚拟化技术细节

    Hyper-V 网络虚拟化技术细节 适用对象:Windows Server 2012 R2 服务器虚拟化能让多个服务器实例在同一台物理主机上同步运行,但各个服务器实例都是相互独立的. 每台虚拟机的运作 ...

  8. Python+Selenium练习篇之16-自定义浏览器窗口大小

    本文来学习下如何通过Selenium方法,设置符合不同测试场景浏览器窗口大小.例如,你有一台机器,最大支持1366*768,你完全可以利用这个机器测试不同分辨率下的场景. 相关测试脚本代码如下: # ...

  9. PAT——乙级1026and1046

    1026 程序运行时间 (15 point(s)) 要获得一个 C 语言程序的运行时间,常用的方法是调用头文件 time.h,其中提供了 clock() 函数,可以捕捉从程序开始运行到 clock() ...

  10. Mysql Error Code: 1175. You are using safe update mode and you tried to update a table without a WHERE that uses a KEY column

    Mysql update error: Error Code: 1175. You are using safe update mode and you tried to update a table ...