学弟学妹少走弯路,超完整算法刷题路线出炉

news2024/11/28 22:48:50

大家好,我是帅地。

本篇文章主要讲解下面三个事:

1、自己学习算法的一些经历

2、大家学习算法存在的一些普遍问题

3、给大家规划的算法刷题路线

一、算法学习往事

记得当初学了 C 语言就开始刷题了,刷题倒不是面试,而是为了通过转专业考试,因为我大一第一学期读的是非计算机专业,了解到转专业需要做 一些简单的算法题,那会我就给同学借了学校的 OJ 账号,开启了一波刷题之路。

到了第二学期转专业考试,也是轻松通过的考试,因为对我来说,那些试题太简单啦。

到了大一第二学期之后,我就慢慢开始学习数据结构了,在 OJ 上也没怎么刷题了,因为比较简单的题都被我刷了,剩下的都是一些比较难的题,有些刷不动,就没刷。

那会刷的题都比较考察思维,没有涉及诸如回溯啊,动态规划啊这些算法思想,不过那会是刷的真爽,因为每次通过一道题就可以升一个等级,刷了比较难的题直接涨 三个等级(当然具体我也忘了,只是记得是这样)。

不过我很庆幸那会的刷题,虽然没有学到各种牛逼的算法思想,但是刷了一两百道题之后,我觉得我的编码能力确实有 不少的题型,比如很多时候,我能够把自己的想法转化成具体的代码,而这种能力,我觉得是非常重要的。

后面学习数据结构的时候,有不少题数据结构,我了解了思路之后,自己就能够试着去写代码了,即使存在不少 bug。

大概第二学期花了两个月学完了《数据结构与算法分析:C语言描述版》这本书之后,根据自己各方面都有了挺大的提升,然后学校也有开设算法选修课,通过选修课也接触了诸如 枚举啊,贪心啊,动态规划,回溯之类的算法思想,不过那会是真的不知道老师在讲什么,特别是动态规划,一上来就是 0-1背包问题,反正我是听的 一脸懵逼。

之后自己就去买了好些书,比如《挑战程序设计大赛》,《编程之美》,还有ACM算法竞赛啥的,反正忘了,总的来说就是,书看的比较多。因为那会不像现在,网上攻略一大堆,网课也一大堆,当然,那会也没有诸如校招等相关信息。

但是我觉得也挺好的,至少学的很爽,也没想着是要笔试,面试啥的,学的比较纯粹,然后也有去一些诸如 杭电OJ 的平台刷了一些题,leetcode 倒是刷的不多,leetcode 是后面校招求职才知道的。

总的来说就是,大一和大二第一学期,在算法上还是花了不少时间,也学的很快乐,但是要说刷题的数量,其实不多,我感觉可能就是三四百道吧,但是我觉得对于 leetcode 上的题,很多题还是可以做出来,包括后面大厂面试,基本都能做出来,笔试的话,有点难,但是也做的还行吧。

总的来说就是,我觉得先打基础非常重要,之后再去学习一些算法思想,之后再刷题巩固。

二、大家学习算法存在的一些普遍问题

刚才我大致说了我算法学习的一个大致路线,相对来说我踩坑是比较多的,比如我是踩了坑之后,再去学习对应的算法思想,而且前期刷了很多基础题,编码能力也还不错。

但是现在的很多人,我觉得编码能力好差啊,比如有些人说已经刷了 300 多道 leetcode 的题了,我以为挺厉害了,但是我让他做题,发现好菜啊,就是不够灵活 + 无法把自己的想法用代码表达出来,而且寻找 bug 的能力也比较差。

而且很多人也是按照 leetcode 的顺序刷题,如果是非初学者,我觉得按照顺序也是没问题的,但是 leetcode 顺序的话,难度分布还是不科学的,如果你硬着头皮去刷,肯定被劝退,比如第十题就是正则表达式

当然,也有很多人直接跟着攻略学习一些算法思想,然后刷题,这样也不是不行,但是如果是初学者,比如学习了一门语言,并且也没做过什么练习题,那么其实编码能力很差的,即使学懂了算法思想,但还是会无法自己独立写出代码,原因就是基础太差,我觉得可以先做一做基础题,再去学这些算法思想,再去刷题吧。

三、给大家规划的算法刷题路线

然后也有很多人问是按照 leetcode 顺序刷题还是分类刷题,其实刷题没有严格顺序,专题刷或者顺序刷都可以,但是这对于初学者来说,容易遇到很难的题,进而被劝退,所以我也给大家规划了一个刷题顺序,如果你没有明确的目标,你可以按照我这个顺序来刷题,本刷题顺序只是基于我个人的刷题理解,挑选了差不多 200 道题,并且会按照循环渐进且相对系统的方式给出题目,反正按照这个顺序刷,以后应付算法面试或者打蓝桥杯这些都是问题不大。

大致目录

image-20230210133458174

当然,这个刷题路线是免费的,大家如果没有明确路线的,可以跟着刷,题量 也是挺多的了,跟着刷完,面试和蓝桥杯这些,应该问题不大。

算法刷题路线地址入口:https://www.playoffer.cn/1216.html

大家加油!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/335545.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

图扑数字孪生智慧社区,助力社区数字化转型

前言 智慧社区是社区管理的一种新理念,是新形势下社会管理创新的一种新模式。智慧社区是指充分利用物联网、云计算、移动互联网等新一代信息技术的集成应用,为社区居民提供一个安全、舒适、便利的现代化、智慧化生活环境,从而形成基于信息化…

[Linux]-Ansible

[Linux]-Ansible 森格 | 2023年2月 介绍:本文旨在介绍ansible的基本使用,提高部署环境时的效率,避免重复操作带来的时间成本。 文章目录[Linux]-Ansible一、什么是Ansible1.1 基本介绍1.2 核心概念1.3 优点二、环境部署2.1 Ansible2.2 Docke…

帮中国人搞钱的ChatGPT,算不清自己的“经济账”

好消息,ChatGPT找到盈利模式了。坏消息,尽是“二道贩子”在赚钱。当OpenAI尝试着为红到发紫的ChatGPT推出20美元的Plus订阅服务时,大多数人已经忘记了这个“吞金兽”的成长耗费了多少财力物力。问答狂欢者的岁月静好靠的是OpenAI的负重前行&a…

可重构或可调谐微波滤波器技术

电子可重构,或者说电调微波滤波器由于其在改善现在及未来微波系统容量中不断提高的重要性而正吸引着人们越来越多的关注来对其进行研究和开发。例如,崭露头脚的超宽带(UWB)技术要求使用很宽的无线电频谱。然而,作为资源…

函数栈帧的创建和销毁——“C”

各位CSDN的uu们你们好呀,今天小雅兰来为大家介绍一个知识点——函数栈帧的创建和销毁。其实这个知识点,我们很早之前就要讲,但是因为我的一系列原因,才一直拖到了现在,那么,话不多说,让我们一起…

(C00036)基于SSM+VUE前后端分离的物流管理系统

基于SSMVUE前后端分离的物流管理系统项目简介项目获取开发环境项目技术运行截图项目简介 本基于SSMVUE前后端分离的物流管理系统,统一管理车辆、顾客、司机、订单等信息,方便企业对物流信息的管理。本系统通过对用户划分为三个角色进行实现,…

【内网安全-横向移动】基于SMB协议-PsExec

目录 一、SMB协议 1、简述: 2、工具: 二、PsExec 1、简述: 2、使用: 1、常用参数: 2、情况: 3、插件 三、PsExec(impacket) 1、简述: 1、impacket&#xff1…

C++-类和对象(上)

类和对象(上)一,构造函数1,概念2,特性二,析构函数1,概念2,特性三,拷贝构造1,概念2,特性四,运算符重载1,概念2,…

联合培养博士经历对于国内就业有优势吗?

2023年国家留学基金委(CSC)申请在即,很多在读博士在关心申报的同时,也对联培经历能否有助于国内就业心中存疑,故此知识人网小编重点解答此问题。之前,我们在“CSC联合培养-国内在读博士出国的绝佳选择”一文…

【论文解读|KDD2020】AKT. Context-Aware Attentive Knowledge Tracing

文章目录摘要1 引言1.1 贡献3 模型3.4 基于Rasch模型的嵌入摘要 知识追踪(KT)是指根据学习者在教育应用中的过去表现预测未来学习者表现的问题。KT最近使用灵活的基于深度神经网络的模型的发展在这一任务中表现出色。然而,这些模型通常提供有限的可解释性&#xff…

HTML画布与SVG(Canvas vs. SVG)

目录 画布(Canvas) 什么是 Canvas? 创建 Canvas 元素 通过 JavaScript 来绘制 理解坐标 更多 Canvas 实例 实例 - 线条 实例 - 圆形 实例 - 渐变 实例 - 图像 相关页面 SVG (Scalable Vector Graphics) 什么是 SVG? SVG 的优势 浏览器支持…

Springboot+Vue java毕业论文选题管理系统

在分析并得出使用者对程序的功能要求时,就可以进行程序设计了。如图展示的就是管理员功能结构图。 系统实现前端技术:nodejsvueelementui 前端:HTML5,CSS3、JavaScript、VUE 系统分为不同的层次:视图层(vue页面&#…

bert处理超过512的长文本(强制改变位置编码position_embeddings )

最近在做 NER 任务的时候,需要处理最长为 1024 个字符的文本,BERT 模型最长的位置编码是 512 个字符,超过512的部分没有位置编码可以用了 处理措施: 将bert的位置编码认为修改成(11024),前512…

【C++】类和对象(二)

目录 一、默认成员函数 二、构造函数 1、构造函数概念 2、构造函数编写 3、默认构造函数 4、内置类型成员的补丁 三、析构函数 1、析构函数概念 2、析构函数编写 3、默认析构函数 四、拷贝构造函数 1、拷贝构造函数概念及编写 2、默认拷贝构造函数 3、拷贝构造…

大学物理·第15章【量子物理】

黑体 斯特藩玻耳兹曼定律 维恩定律 光电效应 在光照射下 ,电子从金属表面逸出的现象,叫光电效应. 逸出的电子,叫光电子 经典理论: 光电流值与入射光强成正比截止频率(红限)v0对某种金属来说,只有…

关于 NodeJs 处理超长字符串问题的分析

问题:对于超大的 string V8不能支持 问题背景 在 Nodejs 计算服务中,对端上上报的内存信息二进制数据进行预处理缓存时,遇到了一个奇怪的报错:RangeError: Invalid string length 。根据该报错信息,查找得知是字符串长…

二叉搜索树(查找,插入,删除)

目录 1.概念 2.性质 3.二叉搜索树的操作 1.查找 2.插入 3.删除(难点) 1.概念 二叉搜索树又称二叉排序树.利用中序遍历它就是一个有顺序的一组数. 2.性质 1.若它的左子树不为空,则左子树上所有节点的值都小于根节点的值 2.若它的右子树不为空,则右子树上所有节点的值都…

代码解析工具cpg

cpg 是一个跨语言代码属性图解析工具,它目前支持C/C (C17), Java (Java 13)并且对Go, LLVM, python, TypeScript也有支持,在这个项目的根目录下: cpg-core为cpg解析模块的核心功能,主要包括将代码解析为图,core模块只包括对C/C/Ja…

Flink 滚动窗口、滑动窗口详解

1 滚动窗口(Tumbling Windows) 滚动窗口有固定的大小,是一种对数据进行“均匀切片”的划分方式。窗口之间没有重叠,也不会有间隔,是“首尾相接”的状态。如果我们把多个窗口的创建,看作一个窗口的运动,那就好像它在不…

大坝安全监测系统:水库“守坝人”!

一、项目背景 随着社会经济的迅速发展,我国水资源利用率越来越高,各类水利水电工规模进一步扩大。在抗洪救灾、水利发电等方面带来巨大的经济和社会效益。但受多种因素影响,大坝的安全问题日益严重。大量工程实践证明,为保证大坝…