{{announcement.body}}
{{announcement.title}}

21 System Design and Object-Oriented Problems for Interviews

DZone 's Guide to

21 System Design and Object-Oriented Problems for Interviews

Practice these frequently asked system design and object-oriented design problems and interview questions.

· Java Zone ·
Free Resource

Hello guys, If you have given any coding interview then you know that System design or Software design problems are an important part of programming job interviews, and if you want to do well, you must prepare this topic. In the past, when I shared my list of programming interview questions, I have shared a couple of System design questions but my readers kept asking me for more questions, as it is a hard topic to master, and more and more practice is needed. 

I had my own list of questions that I have collected from various interviews with friends and colleagues but I needed more questions for this article when I stumbled upon the Grokking System Design Interview course on Educative.

It's like a godsend resource because it not only gives you a lot of System design question but also provide all the knowledge and tools you need to solve those questions.

In other words, this course teaches you to step by step how to proceed with designing a real-world system like Facebook, Twitter, Uber, etc. 

Actually, there are not too many system design interview courses. When I was searching I only find Grokking The System Design course by Educative and Preparing for the System Design Interview course on Udemy by Rajat Mehta. Other than that I didn't find any online course which is completely focused on solving system design problems from top companies like Amazon, Google, Microsoft, Apple, SalesForce, Flipcart, etc. 

Anyway, When you combine this course with this list of questions you will have the best material to prepare for your System design interview. You can also first try all these questions by yourself before joining the course or looking it my solution for some of the questions.

Btw, this works best only if you have some Coding experience and fundamental knowledge of Computer Science and Software Design. If you are a complete beginner in this area then I would suggest you first start with a fundamental course to learn basics like Java Programming: Principles of Software Design on Coursera or Web Application and Software Architecture 101 on Educative itself. 

load balancer

This course will not only teach you how to solve a real-world problem using Java with multiple classes but also software design which is not just coding but also involves logical thinking and design, which is very important for becoming a successful Software Developer.

Top 21 System Design and OOP Design Interview Questions

Without any further ado, here is the list of some of the most popular System design or Object-oriented analysis and design questions to crack any programming job interview.

1. How Do You Design the Vending Machine in Java? (Solution)

You need to write code to implement a Vending machine that has a bunch of products like chocolates, candy, cold-drink, and accept some coins like Nickle, Dime, Quarter, Cent, etc. Make sure you insert a coin, get a product back, and get your chance back. Also, write the Unit test to demonstrate that these common use cases work. If you get stuck you can read my two-part articles (part1 and part 2) about solving these classical system design questions.

2. How Do You Design a URL Shortening Service Like Goo.gl or Bit.Ly? (Solution)

This one is another common System design questions. You have given a (typically) long URL, how would you design service that would generate a shorter and unique alias for it? If you are not familiar with URL shortener service have a look at some of the popular ones like goo.gl from Google and bit.ly which is used by Twitter.

Make sure to provide database schema and rationale behind some design decisions like how long you keep the data, how to get stats and analytics etc. If you get stuck, you can follow the solution given on Grokking the System Design Interview course on Educative.

3. How Do You Design a Traffic Control System?

A classical system design question from old age which is still popular. Make sure you know how to transition from one state to another like RED to GREEN and from GREEN to ORANGE to RED etc.

4. How to Design a Limit Order Book? (solution)

A limit order book is used in stock exchanges to match a buy order with a sell order based on price and time priority. How would you go about that? Which data structure you will use? Remember, the speed of matching is key and also the reliability. If you need a refresher on Data Structure then you can check out Data Structure and Algorithm in Java course and If you feel stuck you can check out my solution here.

5. How Do You Design a Website Like Pastebin?

Pastebin allows you to paste text or code and then share a link to that code anywhere you want. It's not an online code editor but you can use this to store any kind of text.

6. How Would You Create Your Own Instagram? (solution)

Instagram is a photo-sharing application that provides some custom filters to enhance your photo quality. Your application should have photo upload functionality, tagging photos for search, and some basic filters. If you could add share or social network that could be great. Btw, if you stuck, you can see the free solution provided on the Educative's Grokking System design course as well. 

7. How Do You Design a Global File Sharing and Storage Apps Like Google Drive or Dropbox?

These are used to store and share files, photos, and other media. How do you go about designing things like allowing users to upload/view/search/share files or photos? track permissions for file sharing, and allow multiple users to edit the same document?

8. How Do You Design a Chat Application Like Whatsapp or Facebook Messenger?

You have surely used WhatsApp and Facebook, right? No? If not let me tell you that a chat application allows you to send messages to your friend. It's a point to point connection. You keep a friend list and see their status and chat them. In WhatsApp, you can also connect groups but that is for advanced and experienced developers. At a minimum, you should provide a design to keep a friend list and send and receive messages from them.

9. How Do You Design a Twitter Clone?

Twitter is a popular messaging service that lets you broadcast your messages to all your followers. You tweet and your followers see those messages, they can like or retweet. Make sure you implement common features like followers, hashtag, tweet, delete, etc. If you feel not going anywhere and stuck, you can follow the solution on System Design Interviews: Grokking the System Design Interview.

10. How to Design a Global Video Streaming Service Like YouTube or Netflix?

While designing a video streaming service like NetFlix or YouTube key thing is smooth streaming and buffering and functioning over low bandwidth connection, how do you manage those challenges.

11. How to Design an ATM Machine?

An ATM machine allows a user to deposit and withdraw cash. It also allows a user to see his balance. How do you design such a system? What are your main challenges?

12. How Do You Design an API Rate Limiter?

13. How Do You Design Twitter Search?

14. How to Design a Web Crawler Like Google?

A Web Crawler goes to a website and crawl all link and index them like Google so that they can later appear in a search result. A Crawler can also use for searching a particular file in a set of directories, how do you design such things? What are the main challenges?

15. How to Design Facebook's Newsfeed? What Kind of Algorithm Will You Use?

The newsfeed is an important part of Facebook which allows a user to see what's happening around his world which includes friends and families, the pages he has liked, the group he has followed, and of-course the Facebook Ads.

The job of the Newsfeed algorithm is to show messages which are most important for the user and which can generate high engagement. Obviously, messages from friends and family should take priority.   If you feel not going anywhere and stuck, you can follow the solution on System Design Interviews: Grokking the System Design Interview.

16. How to Design Yelp or Nearby Friends?

17. How to Design a Global Ride-Hailing Service E.G. Uber, Grab, or Ola Backend?

Uber and Ola are two of the most popular ride-hailing services, it brings both drivers and passengers together. How do you go about designing to allow a passenger to see nearby taxis and book them?

18. How to Design BookMyShow?

A website that allows you to book cinema and event tickets. This is actually an Indian startup that is doing well.

19. How to Design a Social Network + Message Board Service Sites Like Quora, Reddit, or Hackernews?

Reddit, Quora, and HackerNews are some of the most popular social network sites where users can post questions or share links. Other users can answer questions or comment on the shared links.

20. How Do You Design an Application Like Airbnb?

It allows some users to upload rooms for rent and other users to rent them. Some of the features are only available to admins, publishers, and subscribers.

21. How Do You Design an Elevator of the Lift System?

We All know about Elevators and Lift as most of us use it. You might have seen them in pairs and in some big office buildings you can see 3 to 4 lifts. You need to design software for that so that it can reach use quickly on different levels. You can assume you have two lifts and a 10-floor building.

If you need some guidance then I suggest you check out Preparing for the System Design Interview Course on Udemy, where Rajat Mehta has a whole case study to solve this problem. You will also learn about high-level design, low-level design, and Database design in this masterpiece.

Topics:
careeers, coding, java, jobs, programming, software architecture, software design, system design

Published at DZone with permission of Javin Paul , DZone MVB. See the original article here.

Opinions expressed by DZone contributors are their own.

{{ parent.title || parent.header.title}}

{{ parent.tldr }}

{{ parent.urlSource.name }}