Before sorting out some selected original articles original article selection, see what you missed good articles? “, and then someone asked me if I could sort out all the articles below. To be honest, there are quite a lot of technical articles, I think there are hundreds of them. Finally, I plan to sort out a wave and classify them in detail. But for the public number of this article, even if the arrangement still has some limitations, because there is no bookmark of the folding function, in order to facilitate everyone to locate the search, I here first outline. The order of arrangement is something like

Experience/experience Data structures and algorithms

  1. Basic data structure
  2. Must be algorithm
  3. The algorithm idea and the algorithm topic elaborate
  4. Algorithmic interview questions series

Three. Algorithm brush summary

  1. recursive
  2. Dynamic programming
  3. dichotomy
  4. The list
  5. Binary tree
  6. greedy
  7. Other leetcode topic
  8. Common classical algorithm problems

4. Computer fundamentals

  1. Computer network
  2. The operating system
  3. Computer composition principle
  4. Linux
  5. Database (MySQL)

Learning websites/resource recommendations

Six. Small knowledge popular science

I. Experience/experience

  • Written for a long time, this is a “learning route” suitable for the general public/trainees/non-trainees
  • Along the way, these private collections of useful software/website resources are contributed to you
  • Writing the public account for 15 months, this way of learning and harvest
  • Just so-so, my three years of college
  • After two months, my autumn trick is over!
  • Well, spring recruitment two Tencent interview failed twice, share my failure + silly interview experience
  • What are the algorithms a programmer must know? Let’s talk about the algorithms we’ve learned over the years
  • Leetcode brush 500 questions, the written test/interview is stable? Let’s talk about learning algorithms
  • The computer basics that will take you off: What to learn and how to learn?
  • [Xiao Bai Growth] Introduction to excellent books I have read in recent years
  • The most comprehensive list of Java interview questions in history
  • Summary of some commonly used algorithm techniques
  • How do I learn about data structures and algorithms?

1. Data structure and algorithm

1. Basic data structures

  • Three-minute Basics: What is a two-three-four tree
  • Three-minute Basics: What is a 2-3 tree?
  • Three-minute Basics: What is a queue?
  • Three-minute Basics: What is a stack?
  • Three minute Basics: What is a Linked List
  • Any fool can read it. 30 pictures to understand red black trees!
  • What is a B tree? Why do file indexes use B trees instead of binary search trees?
  • Why do we need a binary search tree and a balanced tree?
  • Why does MySQL database use B+ tree to store index?
  • Throw it to an interviewer who asks about your skip list
  • When an interviewer asks you about AVL trees in the future, throw this article to him.
  • What is binary heap?
  • What is heap sort?

2, must learn the algorithm

  • Old driver teaches girlfriend how to pull a car
  • KMP algorithm for dynamic programming
  • String matching Boyer-Moore algorithm: How is lookup implemented in a text editor?
  • 10 classic sorting algorithms to learn, just read this article (complete code/GIF/excellent article)(revised version)
  • Why is cardinal sort of O(n) complexity not as fast as quicksort?
  • Don’t ask me about quicksort
  • What is external sorting?
  • What is heap sort?
  • Graphical KMP algorithm for string matching
  • Algorithm and data Structure special session BitMap algorithm basic operation code implementation
  • Introduction to BitMap algorithm

3, the idea of the algorithm and the algorithm questions

  • Why can’t you learn recursion? Say goodbye to recursion and talk about some of my experiences
  • Bid farewell to dynamic planning, even brush 40 moving gauge algorithm questions, I summarized the routine of moving gauge
  • How to optimize dynamic programming? I summed up these routines, later optimization is minutes
  • Dynamic programming in detail
  • With this template, my girlfriend no longer has to worry about me not being able to swipe LeetCode
  • What is a concurrent search set? What are the applications?
  • Wow!!!! How to use algorithm to count the number of friend circle?
  • Prefix and the application, from a netease pen test questions
  • Interviewer, please don’t ask me such a simple but tricky algorithm
  • Interviewer, I can design a shuffle algorithm and prove it’s fair
  • 【 Pursuit of perfection 】 How I made the easy level algorithm into hard level.
  • What are the quirks in algorithmic data structures?
  • A story tells the end of the hashed prehistory attack
  • Algorithm techniques bit operation installation guide
  • Factorial is easy, right? With all due respect, you don’t really know the factorial interview questions!
  • Share a clever algorithm to solve the problem
  • Do you really know I ++, ++ I and I +++++ I and I +++ I ++?

4. Algorithmic interview questions series

  • A shopee interview algorithm: the optimal solution of the minimum stack
  • Remember a bytedance algorithm interview question: k linked list node inversion
  • Remember an Ali pen test: how do I solve the Joseph ring problem with a line of code
  • How do you find the most frequent number of 20/40/8 billion integers using only 2GB of memory
  • How do you tell if a number is among 4 billion integers?
  • How to find the top 1000 numbers in a billion
  • [Interview abuse] How to filter sensitive words in the game?
  • 【 Interview spot 】 How to count the number of words with specific prefixes in 500W words?
  • How to program to get the most year-end bonus?
  • The interview hangs on the design of the LRU cache algorithm
  • 【 Interview scene 】 How to program to solve the number of friends?

Second, algorithm brush summary

1, the recursion

  • Why can’t you learn recursion? Say goodbye to recursion and talk about some of my experiences
  • Find the median of two ordered arrays (On the importance of thinking transformation)
  • Find the KTH decimal of two ordered arrays
  • Recursive punch 1: Finds the upper median in two sorted arrays of equal length

2. Dynamic programming

  • Bid farewell to dynamic planning, even brush 40 moving gauge algorithm questions, I summarized the routine of moving gauge
  • How to optimize dynamic programming? I summed up these routines, later optimization is minutes
  • Algorithmic topic (dynamic gauge) : Different definitions lead to different solutions
  • Three one-dimensional dynamic programming algorithms are explained in detail
  • Classic dynamic planning: high-rise eggs thrown
  • Leetcode 221: The largest square
  • Regular expression for dynamic programming

3. Dichotomy

  • Dichotomy question type summary
  • Two seemingly simple interview high-frequency algorithm questions
  • How to understand binary search? Can you use it in your life?
  • Can binary search only be used to find elements?

3, the linked list

  • How to gracefully reverse a single linked list
  • Three ways to judge palindrome lists gracefully
  • [Linked list problem] Reverse the order between each K nodes of a single linked list
  • Delete the KTH node in a single linked list
  • The search binary tree is converted into a bidirectional list
  • Copy a linked list with random pointer nodes
  • [Linked list problem] Divide a one-way linked list into the form of small on the left, equal in the middle and large on the right according to a certain value
  • Circular singly linked list Joseph problem
  • Delete the middle node of a single linked list

4. Binary tree

  • Reconstruction of binary tree by detailed algorithm
  • Post-ordered traversal of binary trees (non-recursive version)
  • Sequential traversal of binary trees (non-recursive version)
  • Middle-order Traversal of binary trees (non-recursive version)
  • Prints the binary tree from the top down
  • The backward traversal sequence of a binary search tree
  • Sword finger offer: binary tree mirror
  • Sword finger offer: substructure of binary tree
  • Sword finger offer: Rebuild binary tree

5, greedy

  • Greed is new to me
  • Leetcode 题 45: Jump Game 2
  • Interval scheduling problem for greedy algorithms

6. Other Leetcdoe questions

  • [leetCode 115]
  • 【leetcode】16. The sum of the nearest three numbers
  • Leetcode 15: sum of three numbers
  • Leetcode 14: the longest public prefix
  • [Leetcode] 13: Roman numeral to integer
  • Leetcode 12: Integer to Roman numeral
  • Most leetcode 】 【 11. The Container With Water | containers of Water are at the Most

7, Common/classic algorithm questions

  • Algorithms: How to find prime numbers efficiently with algorithms?
  • Dynamic programming + binary search solves the longest increasing subsequence
  • Answer a frequent interview question: catch rain

3. Computer fundamentals

1. Computer networks

  • How does one computer send data to another computer
  • How does computer IP come from? I haven’t configured it
  • What is the interviewer trying to ask us about three handshakes and four waves? — No regrets series
  • Broadcast Routing algorithms: How do I gracefully whisper to others
  • What? Why don’t you know 0.0.0.0 and 255.255.255.255?
  • Talk about NAT: What? What are global IP and private IP?
  • TCP traffic control mechanism
  • 5 minutes to understand congestion control
  • [Comics] How do two strange hosts ensure the correct delivery of data?
  • [Comics] HTTPS encryption thing
  • Computer Networking series – what are circuit switching and packet switching?
  • Three minutes of Basics: Explain the TCP three-way handshake with animations
  • Three minutes of basic knowledge: explain TCP four times break up process to girlfriend with animation
  • What is a digital signature? — [Graphic digital signature]
  • Ramble: How to explain to girlfriend why some website domain name does not start with WWW
  • How to distinguish BETWEEN LAN, WAN, WLAN, VLAN and VPN?
  • Enter a URL in the browser address bar and press Enter. What are the technical steps behind this? Be a plus in the interview
  • How do you explain HTTP to your girlfriend
  • Why can’t you access Zhihu using IP, but Baidu can?
  • What is the difference between a hub, switch and router?

2. Operating system

  • Remember an interview: How exactly do processes communicate with each other? —- Say goodbye to rote learning

  • Three-minute basis: What are the classic process scheduling algorithms?

  • Three-minute basis: What is the difference between user-level threads and kernel-level threads?

  • Three minute Basics: The ins and outs of threads, do you understand?

  • A brief explanation of processes and threads

  • Three Minute Basics: Mutual Exclusion (PART 1)

  • Three Minute Basics: Mutual Exclusion (Part 2)

  • In a word, finish heavyweight lock, spin lock, lightweight lock, biased lock, pessimistic, optimistic lock and other locks —- do not look regret series

3. Composition principle of computer

  • Understand the nature of binary complement and stop memorizing it
  • Why are registers faster than memory?

4, Linux

  • [will learn] Linux under the skills of the three musketeers, you dare not learn?
  • What exactly is learning Linux?
  • I’ve got you a Linux that works online
  • Practical command formation remember: the network command -netstat
  • 3 minute Basics: N positions for killing progression Do you know
  • Tencent Ali have asked: online server CPU occupancy rate is high how to check and locate the problem?
  • These Linux tips will greatly increase your productivity
  • Linux startup process

5. Database (MySQL)

  • Tencent interview: a SQL statement execution is slow what are the reasons? — No regrets series
  • MySQL index related
  • How to explain dirty, unrepeatable, and phantom database reads to a new teacher
  • Holy shit, these two tips, my SQL statement not only avoided the pit, but also improved 1000 times (half minute dry goods series)
  • How does an SQL statement execute in MySQL
  • Why does MySQL database use B+ tree to store index?

Learning resources/website recommendations

  • Online CAN use SQL practice platform I find you!
  • Brush thousands of algorithm questions, these my private brush questions website are here!
  • Discover an interesting open source project that teaches you to learn algorithms through animation
  • Programmers job-hopping brush problem necessary artifact! You can swipe LeetCode without opening a browser
  • Here are some productivity tools you use and feel good about
  • Here are some of the most popular Chrome add-ons you can use to search Google without climbing the wall.

Six, small knowledge popular science

  • Small knowledge popular science: short ID and short url can be seen everywhere
  • How to explain to girlfriend hongmeng OS is how to achieve cross-platform?
  • Introduction to Bitcoin
  • What is a neural network algorithm?
  • The math of lotteries

conclusion

These articles, basic programmers must learn knowledge, but also in the interview often test point oh.

Have a harvest? Hope the old iron people come to a triple whammy, give more people to see this article

1, like, can let more people see this article

2, pay attention to the original wechat public number “Shuaidi play programming”, in order to consolidate the basic knowledge of computer (computer network + operating system + database +Linux) and algorithm, recently opened a wechat public number “Shuaidi play programming”, interested in can pay attention to, focus on the algorithm related articles, hee hee. Background reply “ebooks” send you a selection of ebooks package, including a variety of skills of quality ebooks