-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
1 changed file
with
17 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,17 @@ | ||
# Topics For MCQ Test & Interview: | ||
|
||
1. Programming Language - At least one (Preferably Java/C++ (any one), Python (if possible). Java/C++ is needed to understand complex tracing or OOP questions. Python is suitable for when coding on your own because of concise syntax. If you learn one language well enough to code by yourself and can improvise if code snippets written in other languages are given, you are good to go. * Do not forget Bitwise Operators * | ||
|
||
2. Object Oriented Programming and Design. 4 Pillars of OOP. Only theoretical knowledge is not enough try to think about real-life applications and trade-offs. | ||
|
||
3. Data Structures and Algorithms. Array, Linked List, Stack, Queue, Tree, Binary Tree for the basics. If possible, go for Heap, HashMap, Trie, B-Tree and other advanced topics. 🏃🏻 | ||
|
||
4. Algorithms. Linear and Binary Search, 5 Sorting Algorithms (Without HeapSort), BFS, DFS, Tree Traversal, Bit Manipulation. For later rounds, Sieve, Greedy and Dynamic Programming. | ||
|
||
5. Networking. OSI Model, Subnetting, Different protocols (HTTP is the most important, try to learn ins and outs of it including methods, status codes, caching, cookies, authentication and so on), REST Architecture, RESTful APIs | ||
|
||
6. Software Engineering. Architectural Patterns (Basic Knowledge is enough), Design Principles (SOLID, DRY, KISS), Design Patterns (All Creational pattern plus a few other important ones if possible). For later stages, Composition, Dependency Injection, Inversion of Control and some other advanced ones (Google it). | ||
|
||
7. Databases. (SQL vs NOSQL, ACID vs BASE, N+1 Query Problem, DB Normalization, Index, Replication (different types) vs Sharding, ORM vs Raw SQL queries. | ||
|
||
For MCQ, Try to solve some basic Leetcode problems (Preferably easy ones from Neetcode.io). For later stages, at least 100 problem from Neetcode 150 on Neetcode.io. Focus on Array, HashMap, Two Pointers, Sliding Window, Binary Search, Linked Lists, BFS/DFS, Strings, Bit Manipulation, Greedy, 1D DP. |