Тёмный

7. Design Tic Tac Toe game | Tic-Tac-Toe LLD Java | Low Level Design Interview Quest, System Design 

Concept && Coding - by Shrayansh
Подписаться 114 тыс.
Просмотров 71 тыс.
50% 1

➡️ Code (GitLab) Link:
Shared in the Member Community Post (If you are Member of this channel, then pls check the Member community post, i have shared the Git link there)
➡️ Become a Member: / @conceptandcoding

Опубликовано:

 

26 июн 2022

Поделиться:

Ссылка:

Скачать:

Готовим ссылку...

Добавить в:

Мой плейлист
Посмотреть позже
Комментарии : 159   
@manavyadav4382
@manavyadav4382 10 месяцев назад
I have been at this problem for 2 days and have been looking for a correct implementation and explanation. Finally found both in this video!! The only one on yt i think for tic tac toe. Thank you for realising that people start from basic problems❤
@ConceptandCoding
@ConceptandCoding 10 месяцев назад
Thanks
@SuyashD-cd9wr
@SuyashD-cd9wr 3 месяца назад
Hi, This is really good. Keep up the good work.
@manitshah4345
@manitshah4345 Год назад
The parallel drawn wrt java implementation really enriched the content, great video sir😄
@ConceptandCoding
@ConceptandCoding Год назад
thank you
@anshumishra4193
@anshumishra4193 4 месяца назад
Amazing video. One improvement I would suggest is the use of proper access modifiers for methods and variables. Making everything public might be acceptable if someone is interviewing for an SDE-1 position, but for anything above that, it’s important to ensure that proper scopes and access modifiers are applied to each variable and method.
@anantakumarsahu2658
@anantakumarsahu2658 Год назад
Your channel is pure Gold Shrayansh. Thank you so much for this awesome playlist ❤
@ConceptandCoding
@ConceptandCoding Год назад
Thank you
@jaisamtani303
@jaisamtani303 Год назад
@Concept && Coding , this is the optimization we can do: Instead of having while loop and then checking getFreeCells() again and again, we know that in 3*3 tic tac toe, player1 and player2 can play maximum 9 times. Thus, we can use simple for loop from 0 < i < board.size*board size. If any player wins in between, we mark winner flag to true and break, else if for loop is exhausted we know it is Tie, thus redundant getFreeCall() loop is avoided.
@shineinusa
@shineinusa 11 дней назад
Lol, you forgot to handle case explained in the video where player chooses wrong coordinate
@Prashantkumar-pn6qq
@Prashantkumar-pn6qq Год назад
Suggestions : Design Deck of Cards, ATM Machine, Splitwise and Vending Machine. A different set of problems...
@RamKumar-kz8gg
@RamKumar-kz8gg Год назад
can you provide code for the same. It will be nice if you can make video explaining the code and approach. It's high time to start a you tube channel bro
@sameerchoudhary8590
@sameerchoudhary8590 5 месяцев назад
Thank you, this video cleared my understanding of relationships. Should have completed this before watching parking lot LLD.
@ConceptandCoding
@ConceptandCoding 5 месяцев назад
thanks
@user-ho2hk4vx8z
@user-ho2hk4vx8z 10 месяцев назад
wonderful video
@dpynsnyl
@dpynsnyl 11 месяцев назад
Good one. Liked the way you have used code and white paper.
@ConceptandCoding
@ConceptandCoding 11 месяцев назад
Thanks
@jeelpatel02496
@jeelpatel02496 Год назад
I think we can make the board as abstract class and extend it as per different game boards like tictactoeboard, chessboard etc... and we can separate out the logic of checking the winner to the board class. This will help achieve single responsibility principle and also make game class reusable.
@ConceptandCoding
@ConceptandCoding Год назад
thanks sounds good but need to vheck with complete flow but thanks for the input
@aditya_01
@aditya_01 Год назад
thank you very much for such a great content .
@ConceptandCoding
@ConceptandCoding Год назад
Thanks 🙏
@AshishGusain17
@AshishGusain17 7 месяцев назад
Firstly, thanks for the video Shreyansh. I have 2 queries regarding the arrows that you used for class diagram: 1.) The relation between (Board and Pieces) and (Players and Pieces) seems to be of aggregation, but that arrow is not the sign of aggregation. 2.) What exactly that arrow represent as I have not seen that arrow anywhere in class diagrams?
@suddatshende5548
@suddatshende5548 10 месяцев назад
@Concept && Coding where can i find n-queens 2 problem from your channel?
@madhavmishra1864
@madhavmishra1864 Год назад
Thank you for this LLD series. I always get confused between the is-a , has-a , etc. relationships. Could you provide me any book or resources in which I could improve this ?
@ConceptandCoding
@ConceptandCoding Год назад
Hi Madhav, you can refer "Head First Design Pattern" book, its good
@onepercentbetter3313
@onepercentbetter3313 7 месяцев назад
Initially it was said that all the videos are free but I still see many of them are locked. 😢
@world4376
@world4376 3 месяца назад
🥲 same but its worth to spend 199
@raviteja8882
@raviteja8882 8 месяцев назад
can we use factory method pattern to obtain player object?
@abc-ym4zs
@abc-ym4zs 5 месяцев назад
i am not good at designing part and drawing uml diagrams all this stuff should i nned to shift my career to another one like any gove job through ssc cgl any help sir
@curiossoul
@curiossoul 6 месяцев назад
I think isthereawinner() can be moved to board class. Let me know if it makes sense
@dhairyaparekh4739
@dhairyaparekh4739 Год назад
Amazing Content
@ConceptandCoding
@ConceptandCoding Год назад
Thank you
@you-can-do-anything
@you-can-do-anything Год назад
Just a suggestion , i think the GetFreeCells function is only acting as counter we can replace it with that and while checking IsWinner we can exit when we have first match rather than checking for all cases(except n queen).
@ConceptandCoding
@ConceptandCoding Год назад
Try it out buddy, logic sounds good
@shriharikulkarni3986
@shriharikulkarni3986 11 месяцев назад
Hey shreyansh, I was not able to access parking lot video, it says member access is needed, I don’t find member access join button anywhere. Also, I thought you’re doing it for free. Can you pls help me here with link for member access?
@chippapruthvi2773
@chippapruthvi2773 Год назад
Hi Shreyansh, Do we need to make Playing Piece as an abstract class? as some one can directly create object of it without using PieceX and PieceO
@ConceptandCoding
@ConceptandCoding Год назад
Make sense, we can do that
@adarshagrawal3373
@adarshagrawal3373 2 месяца назад
We can apply strategy pattern for winner logic as in future we can have some different logic for finding the winner ? Shrayansh
@RonitSagar
@RonitSagar 2 месяца назад
i am not able to get playing piece class initialisation. How did we are assigning X and O to the player
@himanshuchhikara4918
@himanshuchhikara4918 Год назад
can we have PieceType[][] board instead of PlayingPiece[][] . And if no why no?
@prachij
@prachij Месяц назад
I am not able to find the n queen peoblem on your channel. Could you please share the optimisation logic for finding winner
@your_name96
@your_name96 Год назад
Sir, in this problem, in most interviews, the expectation would be the design + implementation of isThereWinner() method ? Keeping the core design same, I am writing a more generalized and optimised version, thank you sir
@ConceptandCoding
@ConceptandCoding Год назад
:) thanks
@ishangupta7701
@ishangupta7701 10 месяцев назад
your huhhhh at last....🤣🤣
@AnkitSharma-ot5py
@AnkitSharma-ot5py 4 месяца назад
isThereWinner should be in board class or am i thinking in the wrong direction?
@prathmeshmahajan369
@prathmeshmahajan369 Год назад
Hi Shreyansh , thanks for the videos. Can you please make a video on how to structure our codebase. what are models , controllers , services etc...
@ConceptandCoding
@ConceptandCoding Год назад
Noted
@aniketmahangare8333
@aniketmahangare8333 Год назад
Hey shreyansh, why do we need to seprate class for PlayingPiece? We can use enums instead right?
@ConceptandCoding
@ConceptandCoding Год назад
Hi Aniket, to me Piece is an Object which can have both the things "Properties" and "Function". That's why i define it as an object. Rather than enum. But definitely you can also implement the same using enum
@aniketmahangare8333
@aniketmahangare8333 Год назад
@@ConceptandCoding got it, btw thanks for this series Shreyansh. It’s an amazing resource to learn LLDs.
@ConceptandCoding
@ConceptandCoding Год назад
Thank you 🙏
@user-bh3rq8fk1p
@user-bh3rq8fk1p 4 месяца назад
how to join as members..some videos gets like member only
@surendharv795
@surendharv795 6 дней назад
Correct me If I am wrong. Enumerations will violate the Open Close principle in SOLID principles. Hence I think the design should be improved to follow all the SOLID principles.
@sanketneema286
@sanketneema286 Год назад
thankyou bro.
@ConceptandCoding
@ConceptandCoding Год назад
You're welcome!
@akshatshah6413
@akshatshah6413 3 месяца назад
Can anyone please tell Which lld pattern tells us that we should create PieceX and PieceO classes instead of passing piece type directly while creating player object
@ConceptandCoding
@ConceptandCoding 3 месяца назад
Open closed principle, lets say in future you need to add more Piece, you can add it easily
@ANSHULGUPTA880
@ANSHULGUPTA880 Год назад
In the LLD interview, do we have to create diagram only or write code as well?
@ConceptandCoding
@ConceptandCoding Год назад
Both. In 45 mins round, if you can explain with UML, always go for it and try to come up with UML in first 20-25 mins and rest 20 mins keep for coding. Couple of points: - Don't try to create perfect design. - involve interviewer and keep asking for his input.
@SeemaKumari-xv6dc
@SeemaKumari-xv6dc Год назад
Why exactly chain of responsibility pattern needs to be used in case of logger? How else can this be implemented?
@ConceptandCoding
@ConceptandCoding Год назад
Definitely there can be other ways to implement loggers. I used Chain of responsibility to implement it. Could you try to do it some other way, then we can discuss more.
@rasanpreetsingh1712
@rasanpreetsingh1712 6 дней назад
You have already implemented the code but It would be better if you start your explanation basic thought process and intuition behind the design.
@kushrajendragandhi3559
@kushrajendragandhi3559 Месяц назад
I am facing an issue while joining membership where I am unable to proceed further after adding card details. Can someone please guide me
@AyushKumar-zq9ny
@AyushKumar-zq9ny 8 месяцев назад
Hi, I have not given any system design interviews yet in my short career so does the candidate need to develop the whole working solution for an LLD problem or just the class & its methods ?
@ConceptandCoding
@ConceptandCoding 8 месяцев назад
Hi Ayush, there are 2 types of round 1. LLD Round 2. Machine Coding Round In LLD round, usually it held for 45mins, in that full coding sometimes are not mandatory (depends upon company and interviewer), class diagram and sometimes partial coding works out too. In Machine coding round, it happens generally for more than 1:30hrs (depends upon different company), there they do expect full code with usecases which need to be satisfied.
@chidambarjoshi3470
@chidambarjoshi3470 Год назад
In system design interview round, we only need to design the application or also need to code
@ConceptandCoding
@ConceptandCoding Год назад
In some interviews like machine coding round, we have to do complete code too. And in normal LLD round complete code is not mandatory
@sarvanThought
@sarvanThought 2 месяца назад
It would be helpful if you mention whether it's hindi audio or English audio in title. Getting frustrated everytime when I open the design which is hindi.
@srisarveshr6057
@srisarveshr6057 Месяц назад
Hello sir, Iam planning to buy ur RU-vid membership, can you please cover the topics again in English only for the videos in which you have thought in hindi.
@nileshchaudhari3769
@nileshchaudhari3769 Год назад
Sir can you share n queens problem video link ?
@vishalrajput647
@vishalrajput647 2 года назад
Sir, will i need to code this whole in the interview of sde1 amazon or just provide the class diagrams and explanation?
@ConceptandCoding
@ConceptandCoding 2 года назад
interviewer can ask you to code Vishal, its a good question for 60mins interview
@vishalrajput647
@vishalrajput647 2 года назад
@@ConceptandCoding I have last round of interview at amazon most probably bar raiser round, my first two rounds were purely technical rounds which I have cleared so will they ask me to code in bar raiser or ask leadership principles related stuff.. I am so much confused right now..pls help
@ConceptandCoding
@ConceptandCoding 2 года назад
Hi Vishal, i think Bar Raiser round is also rown as Loop round, pls correct me, if this is the case yes in Loop rounds, there will be coding questions+ Leadership principles questions too. Generally Amazon has 5 rounds, of 2 you have cleared then i am thinking its loop round only where rest 3 round will happen including managerial round.
@vishalrajput647
@vishalrajput647 2 года назад
@@ConceptandCoding Things have changed now there are only 4 rounds now. 1 OA + 2 technical + 1 bar raiser.
@ConceptandCoding
@ConceptandCoding 2 года назад
Vishal, i would suggest, you can join this telegram group t.me/+KwJhmit5yDczNzY1 and ask the question
@yashigupta865
@yashigupta865 7 месяцев назад
very helpful
@ConceptandCoding
@ConceptandCoding 7 месяцев назад
Thanks
@yashigupta865
@yashigupta865 7 месяцев назад
@ConceptandCoding, I have joined the community as a member still I am unable to access the videos, is there a specific reason for it?
@vallabhchugh2075
@vallabhchugh2075 7 месяцев назад
please add uml also for easy reference
@tejaswigutta9017
@tejaswigutta9017 Год назад
@Concept && Coding why did we use deque here? Instead, queue can be used right?
@ConceptandCoding
@ConceptandCoding Год назад
Right, queue is sufficient here
@LegitGamer2345
@LegitGamer2345 11 месяцев назад
but how would you add the player to the front in a queue when the cell u specify Is not valid? (filled up)
@justlc7
@justlc7 Год назад
Have a doubt, is this enough for machine coding rounds? They are of 2-2.5hrs, and this can be coded in an hour max Can you clarify this
@ConceptandCoding
@ConceptandCoding Год назад
yes in my view, ot should be sufficient
@justlc7
@justlc7 Год назад
Got it, one more doubt, why are we not making variables private and using getters/setters Is that not required for games or did I miss something? Thanks.
@ConceptandCoding
@ConceptandCoding Год назад
@@justlc7 that would be good practice, i am focusing more on design, might be some gaps in coding implementation parts
@justlc7
@justlc7 Год назад
@@ConceptandCoding Got it, thanks for the prompt replies.
@dhruvsinghal6451
@dhruvsinghal6451 18 дней назад
hi, here can you please explain what is the need of making separate classes for each playingpeice like can't we make a common class here, like enum pieceType then just make two objects of it with X and O type
@ConceptandCoding
@ConceptandCoding 18 дней назад
umm yea thats also correct
@DevanshChiluka
@DevanshChiluka 3 месяца назад
@harshitpandey4839
@harshitpandey4839 Год назад
Do we actually need to check free space every time? Cant we just check the number of free cells by keeping the count? For example in a 3x3 board initially 9 free cells will be there, we can decrease the count each time user makes a move.
@ConceptandCoding
@ConceptandCoding Год назад
Yes we can do. Implementation we can do with many ways, but overall design is imp for this video. But yes there might be efficient way to implement the logic
@gyanaranjanmallick9714
@gyanaranjanmallick9714 Год назад
Hi Shreyansh, I have one query 1. In the video you have 'player' contains 'playingPiece' which in turn contains 'pieceType'(pieceType is enum). What if we don't use 'playingPiece', instead we make 'player' contains 'pieceType'. So we make one less class than earlier. will the second design be better/worse than the first design? And how so? Thanks, great content btw. really appreciate your work.
@ConceptandCoding
@ConceptandCoding Год назад
There is no one solution in LLD, but just think from future perceptive that can more fields will be added in playing piece in future (today it has only piece type), then you have to add them in player class.
@gyanaranjanmallick9714
@gyanaranjanmallick9714 Год назад
@@ConceptandCoding this makes sense. thank you
@muralidharanvasudevan7760
@muralidharanvasudevan7760 7 месяцев назад
Bro, is there a english version?
@learnwithme7750
@learnwithme7750 11 месяцев назад
Hey Shreyansh I have one doubt that as you Game class is doing multiple things so in future if I need to change(or modify) winning logic, so is it following Single Responsibility Principle?
@ConceptandCoding
@ConceptandCoding 10 месяцев назад
yes winning logic can be taken out of it and put in some static util class.
@learnwithme7750
@learnwithme7750 10 месяцев назад
@@ConceptandCoding okay, this code isn't following Single Responsibility Principle, right?
@ConceptandCoding
@ConceptandCoding 10 месяцев назад
Depends, how you are grouping your classes. For example: for each method performing some task, we can not put into different class else we will face class explosion issue. So sometimes we have to group some logical related functionality into 1 class. That's why I said in LLD there is no 1 solution. If you think winning logic does not belong to this class and should be other, go ahead but question is will you create separate class for each method?
@learnwithme7750
@learnwithme7750 10 месяцев назад
@@ConceptandCoding "So sometimes we have to group some logical related functionality into 1 class." this clears as I will not create separate class for each method.
@sachinarora6682
@sachinarora6682 Год назад
Why do we need a deque? Wouldn't a queue suffice?
@ConceptandCoding
@ConceptandCoding Год назад
Right queue is sufficient too.
@Polly10189
@Polly10189 Месяц назад
Amazing content!! Just one query - Do we also need to write code in LLD interview questions?
@ConceptandCoding
@ConceptandCoding Месяц назад
yes
@Polly10189
@Polly10189 Месяц назад
@@ConceptandCoding We are totally totally screwed now!
@nirajbhoyar9462
@nirajbhoyar9462 28 дней назад
Is parking lot problem not free in the playlist ?
@nitin50056
@nitin50056 11 месяцев назад
hi, where can we check the code for these videos in git?
@ConceptandCoding
@ConceptandCoding 11 месяцев назад
gitlab.com/shrayansh8/interviewcodingpractise/-/tree/main/src/LowLevelDesign
@gauravarora5865
@gauravarora5865 6 месяцев назад
why do we need PieceX and PieceO classes. I mean couldn't we simply pass PieceType.X in constructor of playingPiece for a user.. How does this decision make it a better design?
@justlc7
@justlc7 Год назад
Requesting splitwise LLD Thanks
@techworld7765
@techworld7765 7 месяцев назад
@Shreyansh can you pls clarify my doubt that why playing piece class and it's child class is created, we can simply use the PieceTypeEnum only, this will not violate solid principles
@ConceptandCoding
@ConceptandCoding 7 месяцев назад
yes, we can, i just thought in future, if any more playing piece need to be introduced with some specific logic, we can add that here. but for this specific X and O you can you Enum too.
@DilipkumarGangwar
@DilipkumarGangwar 9 месяцев назад
Hi Shraytansh, I have a doubt. addPiece() should be in Board Class or Player Class? I think Player Can add the Piece, so adding piece is player Behaviour . On the other side, we can say Board Object can be modified by adding Piece. By this, we can say addPiece() should in Board class. Which is correct and why?
@vaibhavmalik6490
@vaibhavmalik6490 Год назад
How to find the winner in O(1), please share link of problem that you are referring in video.
@ConceptandCoding
@ConceptandCoding Год назад
Hi kindly check the description, I have shared the link there
@yatri6329
@yatri6329 Год назад
@@ConceptandCoding plz share i checked in the discription
@dineshhardasani415
@dineshhardasani415 10 месяцев назад
I have a question: What happens if both players opt for the same type of playing piece?
@ConceptandCoding
@ConceptandCoding 10 месяцев назад
We can add some validation in the code buddy to avoid these kind of situation
@dineshhardasani415
@dineshhardasani415 10 месяцев назад
​@@ConceptandCoding My second thought was not to keep the playing pieces inside the player and to randomly assign playing pieces to players during the game, eliminating the need for players to change their playing pieces during the game. Would this be a beneficial enhancement, or might it potentially conflict with certain design principles?
@ishabharwal1699
@ishabharwal1699 2 месяца назад
@@dineshhardasani415 i has the same thought...did you get your ans?
@faizaansheikh5233
@faizaansheikh5233 Месяц назад
Hi I already made a payment of 59rupees per month but still unable to access the member only vieeo Please help
@NehaGupta-xu4bw
@NehaGupta-xu4bw 2 месяца назад
I am a member, want to get the Gitlab code link but cannot find it in the member community. Can you please provide any keyword by which I can search it?
@dhruvilthakor3592
@dhruvilthakor3592 2 месяца назад
just type the link and you will get there
@user-cw3pq2uo9w
@user-cw3pq2uo9w 10 месяцев назад
grat
@ConceptandCoding
@ConceptandCoding 10 месяцев назад
Thanks
@mehulparmar9976
@mehulparmar9976 10 месяцев назад
I think you have not checked if row column is more than size.
@ConceptandCoding
@ConceptandCoding 10 месяцев назад
Possible that some validations are missing we can add those
@kusumjoshi4613
@kusumjoshi4613 5 месяцев назад
Please make in c++ too
@ConceptandCoding
@ConceptandCoding 5 месяцев назад
i am not a c++ guy buddy, sorry
@neeranchalgupta1644
@neeranchalgupta1644 10 месяцев назад
Instead of model class for piece can't we make it enum it make code easier
@ConceptandCoding
@ConceptandCoding 10 месяцев назад
There can be many approach, so do try it out
@ashishranjan5225
@ashishranjan5225 8 месяцев назад
It seems code will not work correct for the tie case. All players will get removed from the deque since you are using continue for the case when there is no free cells. It will give null pointer exception. Instead of continue, break should be used.
@ConceptandCoding
@ConceptandCoding 8 месяцев назад
yes, there might be some buisness logic missing, that can be taken care of easily, but i think with this also design will not get impacted.
@subhashismollick5464
@subhashismollick5464 Год назад
Which design pattern follows for this design?
@ConceptandCoding
@ConceptandCoding Год назад
Hi Subhashish, usage of design patterns is not mandatory. Following SOLID principles is imp. As far as i can recollect, it's a very small question, no design pattern is needed for it. But all SOLID principles properly followed
@subhashismollick5464
@subhashismollick5464 Год назад
@@ConceptandCoding Thanks a lot.
@RamKumar-kz8gg
@RamKumar-kz8gg 2 года назад
cpp me bhi code provide kr dete sir, bhut help ho jata
@ConceptandCoding
@ConceptandCoding 2 года назад
Hi Ram, i am not comfortable in CPP, college mein padi thi but 7yr in company using Java only. really sorry buddy, but i will let other members if they can help to provide the same solution in Cpp
@RamKumar-kz8gg
@RamKumar-kz8gg 2 года назад
@@ConceptandCoding Thank You sir
@Prashantkumar-pn6qq
@Prashantkumar-pn6qq Год назад
Hi Ram, I can help you with this , if you still need this. Let me know if you do.
@RamKumar-kz8gg
@RamKumar-kz8gg Год назад
@@Prashantkumar-pn6qq sure bro, please provide the codes
@Prashantkumar-pn6qq
@Prashantkumar-pn6qq Год назад
@@RamKumar-kz8gg I'll try to push it to github by next week
@namrtalakhwan4748
@namrtalakhwan4748 10 месяцев назад
Hi Shreyansh. Let's say i can have different ways to print a board so i make an interface and different printers will implement that interface. Now this interface should be part of game class or the board class? Same doubt with winning strategy? And if we put it in game class then should we pass the whole board object or the matrix only. Keep making such videos❤
@vishwasdhanwani6134
@vishwasdhanwani6134 9 месяцев назад
I think the board interface would be part of board concrete class. And you can make various types of board. In TicTacToeGame class you can use parent board interface for refrencing & apply run-time polymorphism to achieve various types of boards.
@AbhishekSharma-uf1te
@AbhishekSharma-uf1te Месяц назад
link
@ConceptandCoding
@ConceptandCoding Месяц назад
pls check member community post section buddy
@arghyadeepmandal4458
@arghyadeepmandal4458 Год назад
12:39 Tiktok game 🤭
@ConceptandCoding
@ConceptandCoding Год назад
Lol i haven't noticed
@Iamnoone56
@Iamnoone56 10 месяцев назад
Almost all videos are for members only 😢
@ConceptandCoding
@ConceptandCoding 10 месяцев назад
Out of 33 videos only 6 videos (interview asked questions)are for members only buddy. Rest all open. Kindly have a look again pls
@reassume4826
@reassume4826 8 месяцев назад
why are you making most of the videos as members only? I thought u were becoming great just like Striver and what he did for DSA. He still doesn't charge anything...just take some brand promotion or something in the video. This sucks. I really had high hopes from you shrayansh.
@lakshyachhabra7837510764
@lakshyachhabra7837510764 Год назад
Can you please add a video for splitwise LLD Thanks
@ConceptandCoding
@ConceptandCoding Год назад
Noted.