First Round (F2F) 1 hour:
1. Given an image with a lot of pixels, find all the pairs of pixels that are strongly connected.
2. Given an N-ary tree with thousands of nodes, pair the leaf nodes which do NOT SHARE the common path. i.e. Two Leaves can be Paired only if they do NOT have a common edge that was used in a previous pairing.
For example, A / | \ B C D / / | \ E F G H Leaf nodes: E, F, G, H & D Possible Pairs in O/Ps: a) (E-F), (G-H) or b) (E-G), (F-H) or c) (E-H), (F-G) or d) (E-D), (F-G) or e) (E-D), (G-H) or f) (E-D), (F-H) or g) (D-H), (F-G) or h) (D-G), (F-H) or i) (D-F), (G-H)
Note: If we pair(join) say, (E-F) then we can NOT pair any of the (D-G) or (D-H) as they SHARE the COMMON path from A to C.
i.e. E-B-A-C-F —> (E-F) pair D-A-C-G —> (D-G) pair D-A-C-H —> (D-H) pair
So the above case is NOT possible
I tried using a couple of solutions.
Later on used Mathematical Induction (upon his hint)
Basically, a pairing for n = 2 leaf nodes is true
Assume a pairing exists for n = 2k leaf nodes (k > 0)
Now you need to prove a pairing exists for n = 2k+2 leaf nodes
So basically you just have to see the cases where you can insert the new nodes differently
I will probably try to contribute with an article on this.
Code was asked for both the questions.
Second Round (F2F) 45 mins – 1 hr:
1. Given a tree, and a pointer to some node in the tree, print the left most element in the same level as that node
2. Given a C-string, convert it into its ascii string. Ex: “CAR” -> “676582” (C-67, A-65, R-82)
Conditions are that you have to write it in C and you have to do it in place.
3. Lots of questions on programs, Inter process communication, pthreads, java garbage collector etc that went for around 20 mins
Third Round (F2F) 1 hr :
1. Reverse k-alternate nodes in a Linked List
2. Given two strings s1 and s2, find if there exists a substring in s1 which contains an anagram of s2 (in O(n))
3. Given an input of the calendar objects of 10,000 microsoft employees, input is a time interval T and an employee array, find the first interval where all the employees in the employee array are free for a minimum time interval T (i.e schedule the meeting)
I did this question using B+ trees and a Hash, I was told that max flow algorithms can be used.
Fourth Round (F2F) Hiring Manager – 1 hr:
1. Project/previous work
1. Design whatsapp’s back end systems: (we should be able to handle 1 million requests a second and transmit data with least latency)
I had used a lot of distributed systems concepts like message queues, sharding, CDNs, monitoring, InnoDB/MongoDB etc
Preparing questions on Scalability and Distributed Systems is highly recommended.
This site helped me a ton and I hope others will find their dream jobs too !
Thanks geeks 🙂
If you like GeeksforGeeks and would like to contribute, you can also write an article and mail your article to firstname.lastname@example.org. See your article appearing on the GeeksforGeeks main page and help other Geeks.
- Microsoft Interview experience for full time position of software engineer at Microsoft Ireland Research
- Microsoft Interview Experience (Full Time 2018 Washington DC - with 2.5 years of experience)
- Microsoft Interview Experience | Set 151 (SDE-2 3.5 years experience)
- Microsoft Interview Experience | Set 169 (SDE 2 for 3.5 years experience)
- Microsoft IDC Interview Experience | Set 68 (For SDE)
- Microsoft Interview Experience | Set 166
- Microsoft Interview Experience | Set 43
- Microsoft Interview Experience | Set 53
- Microsoft Interview Experience | Set 54 (For SDE)
- Microsoft Interview Experience (SDE II)
- Microsoft interview Experience | Set 50
- Microsoft IDC Interview Experience | Set 88 (For SDE-1)
- Microsoft Interview Experience | Set 45
- Microsoft IDC Interview Experience | Set 88 (For SDE-2)
- Microsoft Interview experience | Set 106