点击上方“码农突围”,马上关注,每天早上8:50准时推送

真爱,请置顶或星标

本文作者:侯振宇,原文链接:https://www.cnblogs.com/sskyy/p/8268976.html

这篇文章最早发在我团队的文档中。我的团队鼓励每个同学都在业余时间多做算法题,特别是新人。个人认为在编程能力的提升上比做 side project 更有用,对职业发展也是如此。当然出于兴趣做的 side project 另当别论。转到这里,希望对各位读者有用。

如何有效地写算法题

目的

持续做算法题的目的仍然是自身能力提升。可以继续细化成三点:

保持思维敏捷。非常重要,状态好才能保持对编程的热情。
对基础的数据结构、查找和排序保持熟练。能解决日常开发中的性能相关问题。
积累对问题域的探索。只有对问题域有足够的探索,才可能举一反三,迸发灵感。

方法

为了更有效地实现上面的目标。推荐用下面的方式来做题:

严格使用番茄时钟进行规划

在刷题的过程中非常最容易产生挫败感,无法坚持。原因是,长时间的思考导致疲倦,多次积累的疲倦使得自己产生了 抵触记忆。以至于会下意识觉得做题就是 刻苦。

推荐大家在开始之前看看《意志力》。里面指出 喜好 是会被记忆操控的,如果每次做一件事最后留下的映像都是轻松愉快的,那么人就会越来越喜欢做此事,反之厌恶。所以为了能保持做题的兴趣,务必每次要主动给自己留下好的记忆。

番茄时钟能够很好地保障不会出现 长时间 的思考,同时也能保障不容易 疲倦。如果你已经能很熟练的使用番茄时钟,请跳过。如果你对番茄时钟的印象仍然只是20分钟休息一次。那么请继续阅读。

番茄时钟有两个重点,一是通过长期的训练,让大脑习惯在一段时间内保持高效。二是通过要求每次在开始前有规划和每次结束后有总结,保障产出。当把这两点应用到做算法的过程中时,应该采取以下的方式:

用一个番茄时钟对题目进行彻底的分析

目前 leetcode 上的题大致可分为几种类型:

  • 对某种复杂规则的彻底解析,很有可能要构造状态机,充分考虑边界情况。

  • 对某种数据结构及算法的应用。

  • 对数学概念、遍历、动态规划等的综合应用。

在这个分析过程中首先要大致判断出属于哪一类。在掌握了基本的数据结构和算法后,应该能很好的判断是不是属于前两类。如果判断不出说明需要回头先重新复习基本数据结构。推荐《算法》一书。不要强行刷题。算法书的每种数据结构及算法的大概思路、解决的问题以及相应的时间和空间复杂度了解之后可以再回来。

第一种情况
例子:https://leetcode.com/problems/valid-number/description/

这个番茄时钟内的目标是:

  • 理清题目背后解法要用的技术

  • 充分收集可能涉及到的边界

完成后应该有的总结是:

  • 是否理清了要用的技术

  • 是否有不确定的地方

  • 收集到的边界是否能覆盖所有情况

如果发现在要用的技术中有不熟悉的地方,应该立即中断,开启另一个番茄时钟进行学习。切忌盲目尝试。当发现有不确定的地方时,重新开启一个番茄时钟,按照当前思路把不确定地方当成一个单独的算法问题进行解决。

第二种情况
例子:https://leetcode.com/problems/reverse-pairs/

这一类题目通常采取遍历的方法一定都能找到解法。重点是找到最优解,因此需要提前有足够的数据结构的知识。数据结构可大致分为链(数组、栈、队列)、树、图。在这三类数据中要分别掌握排序和查找算法。特别是相应的时间复杂度。

这类题目很好判断,通常题目中会描述了几个数据或者状态的关联的关系,然后需要你找出符合条件的某些数据。那么将题目中的关联关系转换成相应的数据结构,再使用对应算法就够了。要对数据结构的足够熟悉,才能知道如何转化。

这种情况下番茄时钟的目标是:

将问题转化为对相应数据结构的问题。

总结是:

  • 需不需要分情况讨论,需要一种数据结构还是多种

  • 相应数据结构是否能完全覆盖题目问题中的所有情况

第三种情况
例子:https://leetcode.com/problems/minimum-window-substring/

这一类情况最好用排除法,发现不是第一种或者第二种,那么再往这种情况下考虑。这类题的特点是通常是发散性质,刚看到题目容易有思路,但不太容易找到最优解。这种情况下,也要先判断题目子类型。

  • 如果发现题目能从遍历的角度解决问题,那么可以往遍历的优化上去想。例如是否在遍历的时候能够排除掉一些情况。或者通过排序等手段之后,能实现遍历时排除某些情况。

  • 如果发现题目中存在多种约束关系,然后求某个值,那么可以往数学方程组上去想。

  • 如果发现问题可以被递归解决,并且能够将递归方式转化成顺序方式,可以往动态规划上去想。

在这种情况下,番茄时钟的目标:
判断出题目类型。

总结:

  • 是否有其他类型更适合。

  • 是否需要多种手段结合。

执行时的番茄时钟

当分析完之后,建议不要开始写代码,一定要休息片刻。执行阶段是对我们平时写代码状态的一种锻炼,应该非常珍惜。如果一个番茄时钟执行不完,应该拆分成多个。在这段时间中,设定的番茄时钟目标应该是:

高效地验证分析阶段的思路

要实现执行高效,最重要的是养成良好的编码习惯,不要犯小错误。要始终朝着只要想清楚了,一次写好,不要调试的状态要求自己。这里常见的小错误有:

  • 拼写错误。变量命名要足够清楚,不要用单个字母或者语意不明的单词。

  • 数组边界未考虑。

  • 空值未考虑。

  • 用 Math.ceil 之类函数时未考虑清楚上下界。

调试超过写代码时间 30% 时说明状态非常有问题。在这个阶段的总结是:

  • 是否完成了对分析的验证

  • 编码过程是否足够高效

如果中间发现了分析阶段的错误或者疏漏。应该立即结束编码,休息。并且重新开启分析阶段的时钟。切忌边写边改方案。如果发现编码过程状态不够好,应该加长休息时间,或者干脆结束掉。不要给自己留下低效的映像。将任务留到第二天其实也可以检验自己第一天的思路是否足够系统化,如果是,那么第二天应该能很快的重新找回思路。

任一番茄时钟结束时

一定要做好总结,特别是当没有解出题来,没有思路的时候,一定要通过结束阶段的总结来反思犯了什么错误。解出来了也一定要总结题目的特点,题目中哪些要素是解出该题的关键。不做总结的话,花掉的时间所得到的收获通常只有 50% 左右。

在题目完成后,要特别注意总结此题最后是归纳到哪种类型中,它在这种类型中的独特之处是什么。经过总结,这样题目才会变成你在此问题域中的积累。

做好总结,让每道题都有最大的收获。一个月之后自己的状态应该会有很大变化。

如何分享

在这个仓库中进行解题分享时,建议大家就把自己番茄时钟的执行记录进行分享。最后标准的解法以及思路其实在 discussion 中都有。对他人有用的分享不是结果,而是:

  • 你在番茄时钟中是如何规划的,也就是番茄时钟的目标。

  • 你是如何分析,也就是思路。

  • 你的结论是什么,或者是你在执行时除了什么问题。

  • 你所总结出的题目的关键部分。也就是对问题域进行探索的经验。

祝各位成长快乐。最后推荐一个公号:

Python技术之巅

Python技术之巅:人生苦短,我用Python,分享Python基础知识、算法和数据结构、爬虫和数据分析相关技术文章,工具资源,精选课程,视频教程,面试题,Python实战案例。

如何有效地刷算法题?相关推荐

  1. 新手如何有效的刷算法题(LeetCode)

    点击关注上方"五分钟学算法", 设为"置顶或星标",第一时间送达干货. 来源:五分钟学算法 前言 作为一名非科班出身的程序员,我是参加工作之后才开始接触算法,学 ...

  2. 牛客网刷算法题的输入输出(C++)

    内容简述 该篇文章将对牛客网刷题中关于输入输出的一些问题作一个总结.每年互联网公司的招聘都必不可少会有算法题,因此平时很多人都会去一些刷题网站进行刷题来学习.这里面用的比较多的刷题网站是leetcod ...

  3. 刷算法题常用的 JS 基础扫盲

    大厂技术  高级前端  Node进阶 点击上方 程序员成长指北,关注公众号 回复1,加入高级Node交流群 介绍 此篇属于前端算法入门系列的第一篇,主要介绍常用的数组方法.字符串方法.遍历方法.高阶函 ...

  4. 靠刷算法题,真的可以刷进大厂吗?

    我一直不知道我在大家心目中的定位是什么,但我内心其实是把自己定义为一个『工具人』的. 可能是因为我自己本身就是程序员,所以更能理解程序员的不易吧. 所以,我尽量不写水文,只分享干货. 就是希望大家看了 ...

  5. 刷算法题需要的java语法_蓝桥杯java b组需要重点刷什么算法呢?

    我觉得这个问题我很适合回答.不过距离我最后一次参赛,已经有了三年,所以回答的内容重点可能有点偏(建议你,可以到网上找找最新的获奖选手赛后总结看看),但是我觉得应该对你有用. 我本科也在湖北,并且参加过 ...

  6. 用Java刷算法题的常用数据结构(C++转Java)

    文章目录 一:前言 1:为何刷题从C++转java 2:如何上手呢? 二:输入 1:常规的输入 2:关于其他输入符在nextLine()之前用吃掉回车符的问题解决 3:常见输入之我们输入一串数到容器中 ...

  7. 【c/c++】刷算法题时常用的函数手册 持续更新--

    在做算法题的时候,有时候为了高效的做题,我们会使用一些函数,但是常用的函数确实太多了,时不时的会忘记一些 于是我整理了一些常用的函数,方便自己查找和别人使用. 都是超链接,点击直接跳转到对应的内容. ...

  8. 字节跳动面试前端岗,刷算法题有救吗?

    在面试中,算法题目是必须的,通过算法能够看出一个程序员的编程思维,考察对复杂问题的设计与分析能力,对问题的严谨性都能够体现出来. 去年,有位学长参加秋招的时候,拿到了字节跳动.快手.阿里.美团--等等 ...

  9. 分享干货:靠刷算法题,真的可以刷进大厂吗?

    在国外 Facebook,Google 等互联网巨头中,算法无疑是面试中的重头戏,不过,在最近几年国内互联网大厂面试中,算法的比重也越来越高,算法不扎实,笔试可能就直接被刷了. 那你知道大厂的技术面为 ...

  10. 为什么要刷算法题与 MATLAB 刷题

    我们常说,算法与数据结构是CS(Computer Science)的核心,而刷题是快速掌握算法与数据结构的唯一渠道,无论你是刚接触代码的小白,还是在大厂工作多年的coder,刷题都是保证技术熟练度的制 ...

最新文章

  1. Ubuntu Tensorflow object_detection API 目标检测环境搭建
  2. vue项目中的tab页实现
  3. avue form提交变为不可编辑_教程42——富文本编辑器的原理(项目)
  4. 用Qt开发游戏时一些问题的解决方法(一)
  5. 安装memcached服务和PECL关于memcache的两个PHP扩展
  6. 359B. Permutation
  7. 女人必知 教你认清6种隐性坏男人
  8. OpenShift 4 - 如何删除Terminating状态的项目
  9. 如何确定恶意软件是否在自己的电脑中执行过?
  10. c# equals与==的区别(转载)
  11. FineUI之使用SQL脚本从数据库表中生成对应的输入控件
  12. 如何将mp4视频转换成aac音频
  13. 视频教程-Visio应用视频教程(上)-Office/WPS
  14. 【转自52v6】教你如何走IPv6下载百…
  15. EDEM创建用于模拟颗粒工厂的多边形后,选中多边形视图中不显示红色多边形
  16. PHP实现简单的注册页面(正则表达式练习)
  17. 常用的项目团队管理方法
  18. HashMap碰撞问题解析
  19. 解决Windows 10 无法安装.msi文件的办法
  20. 反向延长线段什么意思_《反向延长线》

热门文章

  1. Javascript特效:导航栏楼层效果
  2. Dede系统oday漏洞临时修补方法
  3. opencv图像分析与处理(13)- 彩色图像处理基础:彩色模型与伪彩色图像处理
  4. 分布式存储系统学习笔记(二)—分布式文件系统(4)—内容分发网络(CDN)
  5. Network in Network 算法解析
  6. 用CSS绘制实体三角形并说明原理
  7. 清理电脑文件夹中的Thumbs.db文件
  8. Package Control 使用
  9. [Ogre][地形][原创]基于OgreTerrain的地形实现
  10. 石、鋏、布~ 最疯狂的打斗场面,莫要错过,iphone手机游戏