Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/divyashah0510/data-structure
https://github.com/divyashah0510/data-structure
Last synced: about 2 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/divyashah0510/data-structure
- Owner: divyashah0510
- Created: 2024-07-06T16:47:50.000Z (6 months ago)
- Default Branch: master
- Last Pushed: 2024-08-08T14:43:35.000Z (5 months ago)
- Last Synced: 2024-08-08T17:13:44.849Z (5 months ago)
- Language: C++
- Size: 29.3 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
- [Placements at IIT Delhi 2024](#placements-at-iit-delhi-2024)
* [Preparation:](#preparation)
+ [Competitive Programming (CP)](#competitive-programming-cp)
+ [2. Dev/C++](#2-devc)
+ [3. Quant Section](#3-quant-section)
+ [4. CS Fundamentals](#4-cs)
- [1. Computer Networks](#1-cn)
- [2. Operating Systems](#2-os)
- [3. Parallel Programming](#3-parallel)
- [4. Computer Architecture](#4-computer-architecture)
* [Applications:](#applications)
* [Placement Tests:](#placement-tests)
* [Understanding Compatibility](#understanding-compatibility)
* [Interviews](#interviews)
* [After Interviews](#after-interviews)
* [A Side Note](#a-side-note)
* [Some More Prep Links](#some-more-prep-links)
# Placements 2024
[![Hits](https://hits.seeyoufarm.com/api/count/incr/badge.svg?url=https%3A%2F%2Fgithub.com%2Fanirudhakulkarni%2FPlacements-2024&count_bg=%233D8EC8&title_bg=%23555555&icon_color=%23E7E7E7&title=hits&edge_flat=false)](https://hits.seeyoufarm.com)I sat for placements at IIT Delhi. This is a compilation of the preparation I did from August 2024 to November 2024.
## Preparation:
Majorly four components: Competitive Programming, Dev/C++, Quant section and CS fundamentals. I had prepared for quant section during intern phase. I had experience in Dev from my past interns/side projects and C++ from Optiver. My majority prep was doing CP and CS fundamentals.
### Competitive Programming (CP)Important topics: Graphs, Trees, Dynamic Programming, Recursion, and Range Queries. Some Sources of questions:
1. **Leetcode** [Profile](https://leetcode.com/u/anirudhakulkarni/)
- Leetcode hard questions are important. I found solving easy a potential time waste. Some mediums are good but I regret not trying to focus on hard questions only as early as possible.
- Do not look at the solutions without solving for the sake of solving.
- I kept a target of 30 minutes per leetcode hard question until I gave up and saw the hint.
- Leetcode sheets are useful ways to get started: [Striver SDE Sheet](https://leetcode.com/problem-list/eeudwo2i/),
[blind75 sheet](https://neetcode.io/practice),
[Neetcode150 sheet](https://neetcode.io/practice). Solving these sheets is more than enough to clear all the tests. Leetcode premium question [data](https://docs.google.com/spreadsheets/d/1ilv8yYAIcggzTkehjuB_dsRI4LUxjkTPZz4hsBKJvwo/edit?gid=485397084#gid=485397084).
Common Coding Patterns in Algorithm Problems
### Sliding Window
- [Find All Anagrams in a String](https://leetcode.com/problems/find-all-anagrams-in-a-string/)
- [Longest Substring Without Repeating Characters](https://leetcode.com/problems/longest-substring-without-repeating-characters/)
- [Minimum Window Substring](https://leetcode.com/problems/minimum-window-substring/)
- [Longest Repeating Character Replacement](https://leetcode.com/problems/longest-repeating-character-replacement/)
- [Max Consecutive Ones III](https://leetcode.com/problems/max-consecutive-ones-iii/)
- [Minimum Size Subarray Sum](https://leetcode.com/problems/minimum-size-subarray-sum/)
- [Fruit Into Baskets](https://leetcode.com/problems/fruit-into-baskets/)
- [Permutation in String](https://leetcode.com/problems/permutation-in-string/)
- [Longest Substring with at Most K Distinct Characters](https://leetcode.com/problems/longest-substring-with-at-most-k-distinct-characters/)### Subsets
- [Letter Case Permutation](https://leetcode.com/problems/letter-case-permutation/)
- [Generate Parentheses](https://leetcode.com/problems/generate-parentheses/)
- [Different Ways to Add Parentheses](https://leetcode.com/problems/different-ways-to-add-parentheses/)
- [Subsets II](https://leetcode.com/problems/subsets-ii/)
- [Unique Binary Search Trees II](https://leetcode.com/problems/unique-binary-search-trees-ii/)
- [Generalized Abbreviation](https://leetcode.com/problems/generalized-abbreviation/)
- [Subsets](https://leetcode.com/problems/subsets/)
- [Unique Binary Search Trees](https://leetcode.com/problems/unique-binary-search-trees/)
- [Permutations](https://leetcode.com/problems/permutations/)### Cyclic Sort
- [Missing Number](https://leetcode.com/problems/missing-number/)
- [Find All Duplicates in an Array](https://leetcode.com/problems/find-all-duplicates-in-an-array/)
- [First Missing Positive](https://leetcode.com/problems/first-missing-positive/)
- [Find All Numbers Disappeared in an Array](https://leetcode.com/problems/find-all-numbers-disappeared-in-an-array/)
- [Kth Missing Positive Number](https://leetcode.com/problems/kth-missing-positive-number/)### Modified Binary Search
- [Find in Mountain Array](https://leetcode.com/problems/find-in-mountain-array/)
- [Search in Rotated Sorted Array](https://leetcode.com/problems/search-in-rotated-sorted-array/)
- [Peak Index in a Mountain Array](https://leetcode.com/problems/peak-index-in-a-mountain-array/)
- [Find First and Last Position of Element in Sorted Array](https://leetcode.com/problems/find-first-and-last-position-of-element-in-sorted-array/)
- [Search in a Sorted Array of Unknown Size](https://leetcode.com/problems/search-in-a-sorted-array-of-unknown-size/)
- [Find K Closest Elements](https://leetcode.com/problems/find-k-closest-elements/)
- [Find Smallest Letter Greater Than Target](https://leetcode.com/problems/find-smallest-letter-greater-than-target/)
- [Binary Search](https://leetcode.com/problems/binary-search/)### Two Pointers
- [4Sum](https://leetcode.com/problems/4sum/)
- [3Sum](https://leetcode.com/problems/3sum/)
- [Sort Colors](https://leetcode.com/problems/sort-colors/)
- [Backspace String Compare](https://leetcode.com/problems/backspace-string-compare/)
- [3Sum Closest](https://leetcode.com/problems/3sum-closest/)
- [Two Sum](https://leetcode.com/problems/two-sum/)
- [Squares of a Sorted Array](https://leetcode.com/problems/squares-of-a-sorted-array/)
- [3Sum Smaller](https://leetcode.com/problems/3sum-smaller/)
- [Subarray Product Less Than K](https://leetcode.com/problems/subarray-product-less-than-k/)
- [Remove Duplicates from Sorted Array](https://leetcode.com/problems/remove-duplicates-from-sorted-array/)### Tree Breadth First Search
- [Minimum Depth of Binary Tree](https://leetcode.com/problems/minimum-depth-of-binary-tree/)
- [Binary Tree Right Side View](https://leetcode.com/problems/binary-tree-right-side-view/)
- [Binary Tree Zigzag Level Order Traversal](https://leetcode.com/problems/binary-tree-zigzag-level-order-traversal/)
- [Binary Tree Level Order Traversal II](https://leetcode.com/problems/binary-tree-level-order-traversal-ii/)
- [Binary Tree Level Order Traversal](https://leetcode.com/problems/binary-tree-level-order-traversal/)### In-place Reversal of a LinkedList
- [Reverse Linked List](https://leetcode.com/problems/reverse-linked-list/)
- [Reverse Nodes in K-Group](https://leetcode.com/problems/reverse-nodes-in-k-group/)
- [Rotate List](https://leetcode.com/problems/rotate-list/)
- [Reverse Linked List II](https://leetcode.com/problems/reverse-linked-list-ii/)### Topological Sort
- [Minimum Height Trees](https://leetcode.com/problems/minimum-height-trees/)
- [Course Schedule](https://leetcode.com/problems/course-schedule/)
- [Sequence Reconstruction](https://leetcode.com/problems/sequence-reconstruction/description/)
- [Course Schedule II](https://leetcode.com/problems/course-schedule-ii/)
- [Alien Dictionary](https://leetcode.com/problems/alien-dictionary/)### Tree Depth First Search
- [Path Sum](https://leetcode.com/problems/path-sum/)
- [Path Sum III](https://leetcode.com/problems/path-sum-iii/)
- [Sum Root to Leaf Numbers](https://leetcode.com/problems/sum-root-to-leaf-numbers/)
- [Diameter of Binary Tree](https://leetcode.com/problems/diameter-of-binary-tree/)
- [Path Sum II](https://leetcode.com/problems/path-sum-ii/)
- [Check If a String Is a Valid Sequence from Root to Leaves Path in a Binary Tree](https://leetcode.com/problems/check-if-a-string-is-a-valid-sequence-from-root-to-leaves-path-in-a-binary-tree/description/)
- [Binary Tree Maximum Path Sum](https://leetcode.com/problems/binary-tree-maximum-path-sum/)### 0/1 Knapsack
- [Last Stone Weight II](https://leetcode.com/problems/last-stone-weight-ii/)
- [Ones and Zeroes](https://leetcode.com/problems/ones-and-zeroes/)
- [Target Sum](https://leetcode.com/problems/target-sum/)
- [Partition Equal Subset Sum](https://leetcode.com/problems/partition-equal-subset-sum/)
- [Combination Sum II](https://leetcode.com/problems/combination-sum-ii/)### K-way Merge
- [Kth Smallest Element in a Sorted Matrix](https://leetcode.com/problems/kth-smallest-element-in-a-sorted-matrix/)
- [Smallest Range Covering Elements from K Lists](https://leetcode.com/problems/smallest-range-covering-elements-from-k-lists/)
- [Merge K Sorted Lists](https://leetcode.com/problems/merge-k-sorted-lists/)
- [Find K Pairs with Smallest Sums](https://leetcode.com/problems/find-k-pairs-with-smallest-sums/)
2. **CSES** [Profile](https://cses.fi/problemset/user/74593/)
Most of the questions are good. This is probably a good source of questions after leetcode. Some are [ridiculous](https://cses.fi/problemset/task/1160). This [video](https://www.youtube.com/watch?v=dZ_6MS14Mg4) motivated me.3. [**cpalgorithms**](https://cp-algorithms.com/index.html)
This is the bible for algorithms. Data structures, graphs, and trees are a must. You will find the most minimal version of algorithm implementations here. As I solved more and more questions from leetcode/cses/codeforces/tests I found myself going through 99% of the algorithms at least once.4. **Codeforces**
Tests for HFTs sometimes borrow questions from codeforces 2000+ directly. I found dp on graphs questions from codeforces useful.Some more advanced topics especially for HFTs include dp on graph and linear expectations questions on graphs.
This is a very wide area. I felt having practical experience helps here. Some important topics one should consider (in alphabetical order from my notes):
- Casting
- const
- constexpr
- constructors
- copy elison
- design patterns
- diamond problem
- exceptions
- fastio
- filesystem
- friend keyword
- inheritance
- iterators
- lambdas
- linux directory
- lvalue rvalue difference
- move vs copy
- operators
- padding and packing
- references
- signals
- smart pointers
- stack vs heap
- static keyword
- std::threads
- string
- templates
- virtual destructors
- vtableFind youtube videos for each of them separately. I felt this was more than enough for what placement tests expected for. Practice gfg question sets like this [Set](https://www.geeksforgeeks.org/commonly-asked-c-interview-questions-set-1/), [C++ Programming Multiple Choice Questions - GeeksforGeeks](https://www.geeksforgeeks.org/c-programming-multiple-choice-questions/) occasionally. The more you solve the better it is.
Probability is majorly required for quant profiles even though some Dev roles at HFTs also ask them as part of the general aptitude test. This includes probability and mathematical puzzles. I had prepared for this section during intern phase extensively and hence did not spend much time here (~80 questions on weekends and occasional discussion on hard questions from friends).
Xinfeng Zhou [Xinfeng Zhou - A practical Guide to quantitative finance interviews](https://github.com/geniayuan/datasciencecoursera/blob/master/%5BXinfeng%20Zhou%5DA%20practical%20Guide%20to%20quantitative%20finance%20interviews.pdf) and [Heard on the street](https://github.com/pnjha/cp_practice/blob/master/Timothy-Falcon-Crack-Heard-on-the-Street_-quantitative-questions-from-job-interviews-Timothy-Crack-2003.pdf) are *the* gold standard for these questions. Many companies repeat the questions as it is from these books. Some sections such as option theory are not required. [Mark Joshi](https://github.com/geniayuan/datasciencecoursera/blob/master/%5BMark%20Joshi%5DQuant%20Job%20Interview%20Questions%20And%20Answers.pdf) also has some good questions to practice. Some companies ask for linear algebra as well - I did a 4-5 hour refresher for this and got through tests.
Apart from this, I studied topics as I came across:
- Catalan numbers
- correlation
- covariance
- linear expectations
- p-value calculation
- sampling algorithms
- central limit theorem
- simulating probabilities
- random processes
- linear algebra in probability
- almost sure convergenceSome other questions I practiced but were not required as such are: , , brainstellar, geeksforgeeks.
This section is sometimes copy-pasted GFG questions or complex questions with an application of fundamental concepts. There is no middleground. As you start to attempt placement tests, you will find repeated questions again and again.
#### 1. Computer NetworksFor Computer Networks understand the basics and layers. Understanding actual function calls instead of abstract ideas helped me in one of HFT interviews and interviewers seemed to appreciate it a lot. GFG problem sets are good for this.
#### 2. Operating Systems
OS lectures by Sorav Bansal [videos](https://www.youtube.com/playlist?list=PLEAYkSg4uSQ3RTwDexX_T0TU7V9hHM_RO) is the gold standard for OS along with [notes](https://iitd-plos.github.io/os/2020/schedule.html). This series covers OS+parallel+some part of the architecture.I did not find any particular lecture series useful for this. Solving gfg questions and YouTube videos as required helped. Some of the important topics are semaphores, condition variables, threads, locks, etc. Try to apply these topics in practice. HFTs ask some really good questions in this area.
Again, solving occasional gfg questions and reading random slides from MIT helps. Hardware role at HFTs asked for constructing arbitrary truth tables from basic logic gates. Some important topics: Understand cache, cache coherence protocol, associativity, pipelining, size calculation for page table etc. (Someone else could contribute here. I did not prepare for H/W roles).
From my experience, HFT Dev requires CS fundamentals, Dev/C++, CP extensively, and medium to high effort from the probability section depending on what roles you are being considered for.
HFT Quant requires CP, CS fundamentals, and quant section extensively. You could potentially skim through CS fundamentals but still get through.
Tech SDE requires CP, CS fundamentals, and a bit of Dev/C++.
- Should I apply for just “important” profiles?
Getting experience with placement tests is important. I have seen people applying just for “important” profiles and then panicking in tests and not getting shortlists. I shamelessly applied for every profile out there. I experimented with time management and handling stress during tests. The same goes for interviews. I gave several Tech SDE interviews as a mock for tech rounds and HR rounds.
- Very few openings have 9+ CGPA requirements
- Placement tests are mainly CP. Being able to solve a random leet code hard within 30 minutes helped me to get through all of the tests. Few will require CS fundamentals and C++ as well (a must for HFTs). HFT quant will have additional quant sections as well.
- Most of the tests are quite straightforward with a similar pattern of 2 leetcode hard questions with 30 mins each and an MCQ section of CS fundamentals or CP fundamentals or a quant section.
- Some companies shamelessly repeat the questions: Refer to these sheets [Inter IIT Placements 2021-22](https://docs.google.com/document/d/e/2PACX-1vSDJ7BiVSUGaO6tDhv2kDeYDJnZ_TxuhTmg9loZIg6C-jlkfUdaJYdf5XasgbTgbOdDsm9ZK-udGamv/pub#id.bw56fwlrzzox), [Inter IIT Placement 2018-2019](https://docs.google.com/document/d/e/2PACX-1vRqsXE-Izz-qktbRKVexkt_eByPQQzaJ5vRKnd7gMClSINVRDF6tHJwXiVoz0NnJ-V9JamNaUvDEGou/pub), [2019-20 inter iit placement questions ](https://docs.google.com/document/d/1I_N0dUs-SFqJ0E3v2bEZmIqmgCJr3fGD911Nd1En10s/edit#heading=h.36icyhqhrajp)
Apart from this there will be some whatsapp groups, discord channels. It sometimes helps to reduce anxiety or get a place to bitch about companies. Check with your batchmates for this.
## Understanding CompatibilityThis is usually a neglected part of placements. Try to understand the requirements of each profile beforehand. Understand the company culture and see where you fit beforehand. **Do not waste both your time and their time** in this process just to realize it's not the culture you want to join. Avoid fancying any profile. Understand the requirements of all profiles, what is fun to do, and what you can do. Stay away from firms with toxic work cultures.
1. **Across roles:**
1. *Tech SDE* - great for someone looking for work-life balance or wanting to gain tech skills, depending on the firm’s culture. Some tech SDE jobs could require as little as 3 hours of work a day, and some could require as much as 12 hours.
2. *HFT Quant* - No work-life balance. Be prepared to sit from 9:30 AM to 5-7 PM in the office, depending on load. High pay - some firms could be toxic depending upon HR, people in management, and seniors.
3. *HFT Dev* - Same as HFT quant but workload could be a bit more lenient or harsh depending on firms and culture. Less pay after 4-5 years but more employable and less risky compared to HFT quant (~Hire to fire?~)
2. **Startup vs. established:**
1. Established firms relatively have better work-life balance. But relatively lower pay and lower workload. They tend to have established cultures, less uncertainty if company will survice and access to industry pro people.
2. Startups are usually high risk and high reward. More responsibilities and more workload. Usually great if you want to gain skills early in your career or if you want to startup in the future. It is easy to get exploited here.
- Interviews usually start well before (November month) day one (now day 1.1). Most of the HFTs will conduct multiple rounds before. Enjoy the attention you get from companies during this period before day one (*we da best, join us*) Some Tech SDEs tried to conduct interviews this time, but OCS imposed restrictions.
- OCS restricts the number of interviews available on any slot to just five interviews (petition to change this). You can select the preference a day before and get interviews slotted accordingly. I had all HFTs at the top and could not interview for Tech SDE roles on day one. You could be more strategic in filing the preferences to minimize the risk.
- Having a friend with your phone handling interview scheduling can be useful. Companies tend to overshoot the time limit if they like you, and you can easily miss other interviews. You can prioritize beforehand which one to focus on and which one to skip to avoid any miss on the actual day. I skipped the final round for some of the profiles to continue with rounds for prioritized profiles.
- Interview prep: Most of the prep is done while doing the tests. There is nothing to do here towards the end but polishing, reducing the stress and being confident. Give some mock interviews with friends, seniors or anyone who can ask you a leetcode question and judge your response.
1. **CV** - be ready to explain internships and projects, highlight achievements etc
2. **Live coding** - common with tech SDEs
3. **Puzzles and quant questions** - common with HFTs both tech and quant
4. **HR** - be ready with cultural fit questions - *why do you want to join us, why not competitiors, strengths, weakness* etc
5. **Dress well** - ~~plan your haircut well in advance to avoid last minute embarrassments~~
- Not getting what you wanted in the placements is not the end of the world. There will be some openings that weren't available during placements. Approach seniors to check if openings are available.
- Some startups are great yet they don't get a slot at IITs - approach them
- Some firms will approach you after the interviews once you get an offer from competitors ready to match or hike up whatever is being offered.
- I have seen people not solving a single question in on-campus placement tests and yet approach them after placements and bag an offer. **Caution: This does not work with all companies**, so be prepared for being embarrassed if you do so.
- Placements are stressful and can worn you out. Given the current market situation, it is easy to panic/get depressed. IITs usually see several suicides during this phase. Make sure to create a support system with friends, and reach out to counselors.
1. [C++ Coding Standards: 101 Rules, Guidelines, and Best Practices](https://micro-os-plus.github.io/develop/sutter-101/)
2. [Spring 2015 -- Computer Architecture Lectures -- Carnegie Mellon - YouTube](https://www.youtube.com/playlist?list=PL5PHm2jkkXmi5CxxI7b3JCL1TWybTDtKq)
3. [MIT 6.824 Distributed Systems (Spring 2020) - YouTube](https://www.youtube.com/playlist?list=PLrw6a1wE39_tb2fErI4-WkMbsvGQk9_UB)
4. [Arithmetic Game – Online Speed Drill](https://arithmetic.zetamac.com/game?key=a7220a92)
5. [Sparse Table and Fenwick Tree (Binary Indexed Tree) \[CodeISM 2023\] - YouTube](https://www.youtube.com/watch?v=ecJDSQov5eA\&list=PL40a3hTWsqXBFAKwLv-02tsKOLCud6hvf\&index=13)
6. [Full Interview Preparation Cheat Sheet... This will save a lot of time. found this to be really helpful. Hope you also gain benefit from these resources.](https://www.reddit.com/r/cscareerquestionsEU/comments/zesdg8/full_interview_preparation_cheat_sheet_this_will/)
7. [(16) Discord](https://discord.com/channels/996058498657960006)
*PS: After endless Pros & Cons Jams, I finally ended up joining Quantbox Research Capital as Dev.*