Problem Solving In Data Structures & Algorithms... 【ORIGINAL · Playbook】
— Donald Knuth
Dealing with "Top K" elements or frequently updated minimums/maximums. 3. The "Rubber Duck" Debugging Technique
Look for redundant work. Are you recalculating the same value? (Use Dynamic Programming ). Are you searching linearly? (Use Binary Search or a Hash Map ). 2. The Mental Toolkit (Pattern Recognition) Problem Solving in Data Structures & Algorithms...
Always identify the "Brute Force" solution first. Even if it’s inefficient, it guarantees a baseline for correctness and helps you see where the bottlenecks are.
Most DSA problems are variations of a few core patterns. If you recognize the pattern, the solution follows: When to Use It — Donald Knuth Dealing with "Top K" elements
If you get stuck, explain the logic out loud to an inanimate object (or yourself). Translating abstract thoughts into spoken words often exposes the "logic gap" that your brain was subconsciously skipping over. 4. Implementation & Edge Cases
Get it working first, then make it fast, then make it clean. Are you recalculating the same value
Finding the shortest path in an unweighted graph or tree level-order traversal.