“🌟🌟🌟🌟🌟“
“Taste: Meat in pot“
“Cooking time: 20min“
This article has been featured on Github github.com/Geekhyt, thanks to Star.
Why learn data structures and algorithms?
In the year 0202, bombarded by countless messages every day, most people have become increasingly impetuous and have lost the ability to think for themselves.
You may often hear the sentiment:
- How far can technologists go? I hit the ceiling
- How does a 35-year-old programmer deal with a midlife crisis?
- Technology update too fast, I’m too tired to learn
Then, you get anxious too. Have you stopped to think about how you can resist aging and increase your value?
Is nothing more than lifelong learning, continuous cultivation of their own internal skills. Internal work is the basic knowledge and the core concepts, and the essence of the technology that has been developed so vigorously is actually the basic knowledge, the basic courses that we learned in college.
- The operating system
- Computer composition principle
- Computer network
- Compilation principle
- Design patterns
- Data structures and algorithms
That's why the best interviewers pay more attention to your knowledge of the basics, and why the best companies pay more attention to your algorithmic skills. Because when you have that, you're already better than most people. Your ceiling is up to you, and what everyone calls a midlife crisis may not be your crisis. When a new technology comes along, you will see its nature more clearly and learn everything. Such talent, the company will spend less to train you.
(Being a happy CRUD Boy for life is an option, though.)
The relationship between data structures and algorithms
Number 5 in Rob Pike’s 5 Rules of Programming says:
Data dominates. If you’ve chosen the right data structures and organized things well, the algorithms will almost always be self-evident. Data structures, not algorithms, are central to programming.
Data dominates. If you choose the right data structure and organize it properly, these algorithms are almost always self-explanatory. Data structures, not algorithms, are at the heart of programming.
Swiss computer scientist Algol W, Architect of Modula, Oberon and Pascal Niklaus Emil Wirth wrote the classic book Algorithms + Data Structures = Programs, Algorithm + data structure = program.
We can draw the conclusion that data structure and algorithm are mutually complementary. Data structures serve algorithms, and algorithms operate on particular data structures.
Data structure and algorithm are very difficult, how to learn?
- Is there something wrong with me? Not intelligent enough?
- Math is so hard. I’m not born good at math
- You finally figure out an algorithm, and you forget it a few days later
I had my doubts for a while while I was swiping LeetCode, but as IT turns out, it wasn’t. Learning is against humanity, it is important to persist. Data structures and algorithms are not suitable for piecemeal learning. You need to plan for blocks of time first. Then start with the most basic data structure, from easy to difficult, from shallow to deep. You’ll find out later. In fact, the foundations of data structures are arrays (sequential storage) and linked lists (chained storage).
Queues and stacks can be implemented through arrays and linked lists, respectively
We usually implement heaps in arrays (full binary trees), but we can also implement linked lists (binary search trees, red black trees, AVL, B trees, etc.)
A graph is an adjacency matrix implemented in a two-dimensional array and an adjacency list implemented in a linked list
Hash can be resolved using linked lists (zipper) or arrays (linear detection)
So, keeping these basic concepts in mind can help you learn complex data structures and algorithms.
(Too many algorithms, please allow me to write another column)
What if I can’t remember it for a long time?
The national Training Laboratory in Maine, USA, has conducted experiments on the learning pyramid, which was first proposed by Edgar Dale, an American scholar, in 1946.
Human learning is divided into passive learning and active learning two levels.
Passive learning: listening, reading, listening and demonstrating. The average retention rate for learning content is 5%, 10%, 20%, and 30%.
Active learning: discussing, practicing, and teaching to others, with average retention rates of 50%, 75%, and 90%.
It’s a theory you’ve probably heard before, but how many people actually practice it?
The same goes for data structures and algorithms, so you’ll need to get into the habit of doing one problem of the day in LeetCode and review the parts you’ve forgotten. In addition, practice active learning. Find like-minded partners, exchange and progress together. You can also provide solutions on open source projects as a way to teach others.
Lucifer’s LeetCode problem solving library has 30K+ Star. I have submitted some problem solving. When you write the problem solving, you will find that this is the real test of your mastery.
Lucifer’s LeetCode solution
Application of data structure and algorithm in front end
-
The FAMILIAR DOM tree, AST tree, and Virtual DOM of Vue and React are all trees.
-
React Hooks are arrays in nature, React Fiber is implemented based on linked lists.
-
The LRU algorithm is used for both HTTP cache response messages and Vue’s keep-alive.
-
The browser forward and backward function is implemented through the stack.
-
Epoll is used for multiplexing TCP connections, and the reason why epoll is efficient is that the data structure uses red-black trees and queues.
-
Search engines use breadth-first search strategies.
If you know Linux, Nginx, databases, and some message queues, you’ll see applications of data structures and algorithms everywhere. Here are a few examples:
Linux
Process scheduling, process space management usedRed and black tree
Linux
To improve the processing efficiency of directory objects in the file system:LRU, hash table
Linux
The routing tableTire tree
Nginx
Define cache key usedRed and black tree
MySQL
Database index usageB + tree
Improve query efficiencyRedis
Based on the size and quantity of data in most development scenarios, the data structure is more suitable for storage. (Small amount of data using array subscript fast access, small memory footprint. But because the array needs to occupy the continuous memory space, so when the amount of data is large, the linked list is used, and at the same time, in order to give consideration to speed and need to combine with the array, thus having the hash table.- Distributed message queues,
RocketMQ
,Kafka
It is also a kind ofThe queue
.
Shortcuts to data structures and algorithms?
Brushing is a shortcut.
Yes, you read that right.
In fact, and computer communication is really very simple, you give him input, he will give you output. Much nicer than a girlfriend.
Nuggets of pamphlets, open source projects and book list recommendations
The nuggets pamphlets
Xiuyan’s “Front-end Algorithm and Data Structure Interview: Low-level Logic Interpretation and DACHang Real Question Training”, I was lucky to participate in the trial reading in the early writing of the small volume, Xiuyan big boss nanny level tutorial, don’t buy Regret series.
The open source project
-
Lucifer’s Solution to LeetCode, as mentioned above, has 30K+Star, and his new book may be a problem solving book that can completely change your efficiency of scrolling LeetCode
-
If you like to watch the video, you can watch the video to solve the problem
-
Lucifer single can flirt! Get a treasure girl and take him!
book
primary
- Algorithm diagram
- Big talk about data structures
- The beauty of the algorithm
- The beauty of mathematics
- Data structures and algorithms described in JavaScript
classic
- algorithm
- Introduction to algorithms
collection
- Computer programming
Write in the last
Galileo once said, “The book of the universe is written in the language of mathematics.”
Mathematics is not only the formula I learned in school, but also a mode of thinking. Therefore, what I need to improve is the ability of induction, summary and abstraction.
We still have a long way to go.
❤️ Love triple punch
1. Please give me a “like” when you see this. Your “like” is the motivation for my creation.
2. Pay attention to the front canteen of the public account, “your front canteen, remember to eat on time”!
3. This article has been included in the front canteen Github github.com/Geekhyt, for a small Star, thanks to Star.