How to pass a technical interview for a fresh Software Engineering role?

Today two guys asked me about how to pass an interview for a Software Engineering position (as I was offered SE jobs from Palantir and Google, and failed at tons of others). My answer was simple: think hard of a good solution and speak out loud what you are thinking, try to code without bugs, know how to test it and know what you are talking about, especially different data structures.

What I mean by “know” is that you should be able to explain the concept in a simple way and to answer most of the questions related to the concept.

To give an example, in an interview question, you can be asked: “Given a stream of sales: (item_id, number_of_items), how would you recommend a top N best-selling items”. Then be prepared to expect the conversation to be like:

Possible Question: how do you solve the problem?
Possible Answer: I use a max heap to remain the order of items with most sales. For any query, I return the top N items out of the heap. It takes O(NlgK) where K is the number of items in the heap.
Possible Question: How do you update the heap when a new tuple is received?
Possible Answer: For each tuple received from the stream, I update the counter of item_id in the heap, it takes O(lgK).
Possible Question: How do you know which node in the heap to update?
Possible Answer: In order to know which node to update in the heap, I use a hashmap item_id->node_id to keep track of where the item is located in the heap.
Possible Question: How does a hashmap work?
Possbile Answer: It keeps a list of linked list of (key, value). For lookup/modification, it uses the hash function of the key to locate the linked link, then iterates through the linked list to search for the key or add the new item to the linked list.
Possible Question: Implement a hashmap?
Possible Answer:
class HashMap(object):
def put(k, v):
….
def get(k):
….
Possible Question: How to remain O(1) for get/put?
Possible Answer: Keep the hash function of the key to be uniformly distributed.
Possible Question: What happens when the number of items is larger than the size of the list.
Possible Answer: I double the size of the list. Then, redistribute the items to the new list based on the hash(key) % list.size
Possible Question: How do you design the hash function?
Possible Answer: Do s.t like this: f(x)=(((31+x.t1)31+x.t2)31+x.t3) as suggested in Effective Java by Joshua Bloch.
Possible Question: Why do you choose 31?
Possible Answer: Because 31 is prime
Possible Question: Why do you choose a prime number?
Possible Answer: Assuming k=abf(x)=(((ab+t1)ab+t2)ab+t3)f(x)=(((abab+t1ab+t2)ab+t3)=(((ababab+t1abab+t2ab+t3)).    Then, (t1=a,t3=abab)  collides with (t1=1,t3=aabab). Hence, the less factors k has, the less collisions can happen.
Finally, interviewer will possibly say “cool”. Other possible questions include “how does the heap work?”, “implement a heap”, “what if I want top N-items in only last week”, “how to get top N from the heap in O(NlgN)”, “how does arraylist work?”, “implement LRU”,…

Make sure you know when interviewing for a grad level role:
  • Data structures: array, vector, trees, queue, stack, heap, hashmap, treemap.
  • Algorithms: sorts, recursive programming, dynamic programming, string matching, basic Graph algorithms (BFS, DFS, Dijkstra).
  • Concurrency: forking, deadlock, mutex, semaphore, Map/Combiner/Reduce.
  • Memory allocation and garbage collection.
  • Sql, database transaction and different isolation levels.
  • Bit operations: |, &, ^, <<, >>.
  • How disk works (seek, read, write).
  • Maintainability: different design patterns, git/svn, service-oriented architecture.
  • Scalability: load balancers, cache, proxy, index, shards, queue, replication.
  • Availability: share-nothing architecture (so SPOF), eventual consistency, RAIDs.
  • Consistency: vector clock, CAP theorem, FLP theorem, different levels of consistency, 2 phase, 3 phase commit, names of some concensus algorithms, consistent hashing, gossip protocols.
  • Basic concrete maths and probability.
  • Zen of Python (my bonus ;)).
Places to practice: Leetcode, Careercup, Glassdoor. Topcoder and Codeforces for more advanced algorithms.

Apart from technical performance, make sure you are polite, humble, and clear. Despite all of these effort, you still may fail for some unknown reasons. Not all interviewers are looking for the same thing or there will be other people who can do better than you. Just try your best and move on.

252 comments :

«Oldest   ‹Older   201 – 252 of 252
alexsamcurren 3 said...

Good Niche ! Thanks for sharing such a wonderful blog here...
AWS Training in Velachery|
Hardware and Networking Training in Velachery |
Web Designing Training Center in Velachery
JAVA Training in Velachery|
CCNA Training in Velachery |
CCNP Training in Velachery |
Python Training in Velachery|

kamali said...

I am reading your post from the beginning, it was so interesting to read & I feel thanks to you for posting such a good blog, keep updates regularly.


Linux Training Institute in Velachery |
Linux Training Institute in Chennai |
Linux Training Institute in Tambaram |
Linux Training Institute in Taramani|
Linux Training Institute in Medavakkam

alexsamcurren 2 said...

Good Article ! I really Learned lot of information Thank you for updating such an informative content.
Certified Ethical Hacking Training in Chennai|
Certified Ethical Hacking Training in Velachery|
Certified Ethical Hacking Training in Tharamani|
Certified Ethical Hacking Training in Perungudi|
Certified Ethical Hacking Training in Thambaram

anjali said...

Excellent information. Thanks for sharing such a great blog with us.
Linux Training Institute in Chennai | Linux Training Institute in Tharamani | Linux Training
Institute in Medavakkam
| Linux Training Institute in Velachery

alexsamcurren said...

Useful information and Please keep updating us..... Thanks for sharing...
CCNA Training in Velachery |
CCNP Training in Velachery |
Python Training in Velachery|
Certified Ethical Hacking Training in Velachery|
AWS Training in Velachery|
Hardware and Networking Training in Velachery |
Web Designing Training Center in Velachery

venusha said...

Awesome article you have shared, thank you so much for posting such a useful information..
PCB Design Training Institute in Chennai | PCB Designing Training Center in Velachery | Online PCB Design Courses in Chennai | PCB Courses in Velachery

venusha said...

Good Post!!... Thank you so much for sharing your pretty article...
Embedded System Training Institutes in Chennai | Embedded Training Center in Velachery | Embedded Training in Chennai | Embedded System Training in Velachery | Online Embedded Courses in Velachery

venusha said...

I have read your blog, its really very attractive and impressive. I like your content. Thanks for sharing such an amazing information with us...
PMP Certification In Chennai. |
PMP Certification In velachery. |
PMP Certification In medavakkam |
PMP Certification Pallikaranai. |
PMP Certification In Tharamani. |
PMP Certification In Thiruvanmiyur.|
PMP Certification In perungudi. |
PMP Certification In Thambaram..

anjali said...

Excellent article. blog which you shared is very interesting and helpful.
IELTS Exam Center in Chennai | IELTS Exam Center in Velachery | IELTS Exam Center in Medavakkam | IELTS Exam Center in perungudi | IELTS Exam Center in Tharamani | IELTS Exam Center in pallikarani


anjali said...

Great post...Thanks for your valuable post
CCNP Training Institute in Chennai | CCNP Training Institute in Perungudi | CCNP Training Institute in Tharamani | CCNP Training Institute in Medavakkam

venusha said...

Thanks for giving nice information from your blog...It's really an amazing post...

ISTQB Certification in Chennai | OISTQB Exam Center in Velachery | ISTQB Certification in Velachery | Online Certification in Chennai

alexsamcurren 3 said...

It is a one of the great Explanation, which is very essential for me as well.
JAVA Training in chennai |
Python Training in chennai|
Dot Net Training in chennai |
Web Designing Training Center in chennai |
AWS Training in chennai|
Certified Ethical Hacking Training in Chennai|
Linux Training in chennai |
Hardware and Networking Training in chennai |

anjali said...

The Information that is shared is very nice and interesting.
Linux Training Institute in Chennai | Linux Training Institute in Tharamani | Linux Training Institute in Medavakkam | Linux Training Institute in Velachery

anjali said...

Interesting blog....
PMP Exam Center in Chennai | PMP Exam Center in Velachery | PMP Exam Center in Medavakkam | PMP Exam Center in Perungudi

alexsamcurren 2 said...

Nice blog. I feel really happy to have seen your webpage and look forward to so many more entertaining times reading here. Thanks once more for all the details.
JAVA Training in Chennai & velachery |
Python Training in Chennai & velachery |
AWS Training in Chennai & velachery|
Certified Ethical Hacking Training in Chennai & velachery|
Linux Training in Chennai & velachery |
Hardware and Networking Training in Chennai & velachery |
Dot Net Training in Chennai & velachery |
Web Designing Training Center in Chennai & velachery |

alexsamcurren 3 said...

These provided information was really so nice, thanks for giving that post and the more skills to develop after refer that post.
Web Designing Training Center in Chennai & velachery |
JAVA Training in Chennai & velachery |
Python Training in Chennai & velachery |
AWS Training in Chennai & velachery|
Certified Ethical Hacking Training in Chennai & velachery|
Linux Training in Chennai & velachery |
Hardware and Networking Training in Chennai & velachery |
Dot Net Training in Chennai & velachery |

anjali said...

Excellent blog with excellent content...
PCB Design Training in Chennai | PCB Design Training in perungudi | PCB Design Training in tharamani | PCB Design Training in velachery


venusha said...

Good Post!!!... Its really an informative information you have shared, thank you so much for posting useful article..

MBA Project Center in Chennai |
MBA Projects in Velachery |
MBA Projects in Perungudi |
BBA Projects in Chennai |
BBA Projects in Velachery |
MBA HR Projects in Chennai |
MBA Finance Projects in Velachery |
MBA Marketing projects in Velachery

pavi said...

Excellent content with useful information. I am looking forward for your future posts. Keep up the Good work.


CCNA & CCNP Training Institute in Velachery |
CCNA & CCNP Training Institute in Chennai |
CCNA & CCNP Training Institute in Tambaram |

anjali said...

very interesting article...
Embedded system Training Institute in Chennai | Embedded system Training Institute in Chennai | Embedded system Training Institute in Medavakkam | Embedded system Training Institute in perungudi | Embedded system Training Institute in Velachery

srihariparu said...

This is useful post for me. I learn lot of new information from your post. keep sharing. thank you for share us..
Software Testing Training in Chennai | Software Testing Training in Velachery | Manual Testing Training in Chennai | Software Testing Training in Taramani

alexsamcurren 2 said...

Pretty article! I found some useful information in your blog, it was awesome to read, thanks for sharing this great content to my vision, keep sharing.
AWS Training in Chennai & velachery|
Certified Ethical Hacking Training in Chennai & velachery|
Linux Training in Chennai & velachery |
Hardware and Networking Training in Chennai & velachery |
Dot Net Training in Chennai & velachery |
Web Designing Training Center in Chennai & velachery |
JAVA Training in Chennai & velachery |
Python Training in Chennai & velachery |

srihariparu said...

Excellent article.. Thanks for sharing

C & C++ Training in Chennai | C & C++ Training in Velachery

Sathithya said...

Amazing blog with informative information... Thanks a lot for sharing such an wonderful post with us...
PCB Design Training in Chennai | PCB Training Institute in Velachery

venusha said...

Really Very amazing blog with useful

information... Thanks for sharing such a nice

post..

Final Year Project Center

in Chennai
| Final Year Projects in

Velachery

alexsamcurren said...

Very useful post you are shared. I am getting lots of information from your site. Keep posting . Thank you...
JAVA Training in Chennai |
Python Training in Chennai|
AWS Training in Chennai|
Certified Ethical Hacking Training in Chennai|
Linux Training in Chennai |
Hardware and Networking Training in Chennai |
Dot Net Training in Chennai |
Web Designing Training Center in Chennai |

Gayathri said...

Really nice blog.. Thanks for posting this interesting article with us
AWS Certification in Chennai | AWS Exam Center in Velachery

srihariparu said...

Really nice blog.. Thanks for sharing..

GMAT Test Center in Chennai | GMAT Test Center in velachery

Gayathri said...

Nice Blog. Thank you for Sharing..
Python Training Institute in Chennai | python Training in Velachery

alexsamcurren said...

Interesting post. This is really helpful for me. I like it. Thanks for sharing.
JAVA Training in Chennai |
Python Training in Chennai|
AWS Training in Chennai|
Certified Ethical Hacking Training in Chennai|
Linux Training in Chennai |
Hardware and Networking Training in Chennai |
Dot Net Training in Chennai |
Web Designing Training Center in Chennai |

alexsamcurren said...

Nice Post. Thanks for sharing. Keep on updating.
Certified Ethical Hacking Training in Chennai & Velachery|
Linux Training in Chennai & Velachery |
Advanced & Core JAVA Training in Chennai & Velachery |
Python Training in Chennai & Velachery|
Hardware and Networking Training in Chennai & Velachery |
Dot Net Training in Chennai & Velachery |
Web Designing Training Center in Chennai & Velachery |
AWS Training in Chennai & Velachery|

alexsamcurren said...

Nice post. It was really effective. Thank you for sharing.
Certified Ethical Hacking Training in Velachery|
Linux Training in Velachery |
Advanced & Core JAVA Training in Velachery |
Python Training in Velachery|
Hardware and Networking Training in Velachery |
Dot Net Training in Velachery |
Web Designing Training Center in Velachery |
AWS Training in Velachery|

alexsamcurren said...

Thank you so much for sharing this worth able content with us. The Niche taken here will be useful for my future programs and I will surely implement them in my study.
Hardware and Networking Training in Chennai and Velachery |
Dot Net Training in Chennai and Velachery |
Web Designing Training Center in Chennai and Velachery |
Certified Ethical Hacking Training in Chennai and Velachery|
Linux Training in Chennai and Velachery |
Advanced & Core JAVA Training in Chennai and Velachery |
Python Training in Chennai and Velachery|

alexsamcurren said...

Thank you so much for sharing this worth able content with us. Keep blogging article like this.
Advanced & Core JAVA Training in Velachery |
Python Training in Velachery|
Hardware and Networking Training in Velachery |
Dot Net Training in Velachery |
Web Designing Training Center in Velachery |
Certified Ethical Hacking Training in Velachery|
Linux Training in Velachery |
AWS Training in Velachery|

srihariparu said...

Really an amazing blog with useful content.. Thanks for sharing.
CP SAT Selenium Certification in Chennai | CP SAT Selenium Certification in Velachery

alexsamcurren said...

Good Post! Thank you so much for sharing this Awesome post, it was so good to read and useful to improve my knowledge as updated one, keep blogging…
Linux Training in Chennai and Velachery |
AWS Training in Chennai and Velachery|
Advanced & Core JAVA Training in Chennai and Velachery |
Python Training in Chennai and Velachery|
Hardware and Networking Training in Chennai and Velachery |
Dot Net Training in Chennai and Velachery |
Web Designing Training Center in Chennai and Velachery |
Certified Ethical Hacking Training in Chennai and Velachery|

alexsamcurren said...

Interesting post. This is really helpful for me as a career Growth. Thanks for sharing……
Certified Ethical Hacking Training in Guindy|
Linux Training in Guindy |
AWS Training in Guindy|
Advanced & Core JAVA Training in Guindy |
Python Training in Guindy|
Hardware and Networking Training in Guindy |
Dot Net Training in Guindy |
Web Designing Training Center in Guindy |

Bama said...

The article is very informative...
AWS Training Institute in Chennai | CCNA Training Institute in Chennai | Linux Training Institute in Chennai

anjali said...

very useful blog shared with us ...
AWS Training Institute in Chennai | CCNA Training Institute in Chennai | Linux Training Institute in Chennai

srihariparu said...

Wow!!... Superb blog with wonderful information..
PCB Design Training Institute in Chennai | PCB Design Training Center in Velachery

anjali said...

very excellent blog . . .
AWS Training Institute in Chennai | CCNA Training Institute in Chennai | Linux Training Institute in Chennai | CCNA Training Institute in Velachery

srihariparu said...

Really an amazing post with useful information. keep updating..
GMAT Test Center in

Chennai
| GMAT

Test Center in Velachery

anjali said...

excellent blog with informative content...
Selenium Training Institute in Chennai | Selenium Training Institute in Chennai | Selenium Training Institute in Medavakkam | Selenium Training Institute in Tharamani

Reshma said...


Awesome blog. Thanks for sharing such a worthy information....
Java Training in Bangalore
Java Classes in Pune

fagenyanta said...

Best Slot Machine Games Online for Android - JDH Hub
Play the งานออนไลน์ best slots 천안 출장마사지 at JSlot 고양 출장마사지 for free online without registration. JSlot offers an instant play, a sign up bonus for 광주 출장마사지 an instant play. Rating: 5 · ‎2 용인 출장안마 votes

cadeasy said...

Nice reading, I love your content. This is really a fantastic and informative post. Keep it up and if you are looking for http://www.cadeasy.in/ then visit cadeasy.

JENENI said...

Alltechzsolutions provides 100% real-time, practical and placement focused CCNA training in Chennai. Our CCNA course concentrates from basic level training to advanced level training. Our CCNA® training in completely focused to get placement in MNC in Chennai and certification on CCNA after completion of our course. Our team of CCNA trainers are CCNA certified professionals with more real-time experience in live projects. Our CCNA® Course syllabus is enough for anyone who wants to get CCNA certification which meets industry expectations. In our course plan, you will learn Networking concepts,OSI – Model,TCP/IP Model & Ipv4 Addressing, with practical exercises and live examples.Alltechzsolutions offer both off line and online courses.

DLK Technologies said...

Thank you so much for sharing this information. Do visit cse projects in chennai

Inga Cotter said...

Thanks for sharing Blog.. Rug Online Australia

Inga Cotter said...

Thanks for Shairng Blog.. Rug Online Australia

Custom Logo Design Services said...

Thanks for sharing Blog.. custom logo design services

Custom Logo Design Services said...

I Love Blog and all the information. Thanks for sharing.. unlimited graphic design services

«Oldest ‹Older   201 – 252 of 252   Newer› Newest»