Collision Handling In Hash Table - Data Structures & Algorithms Tutorials In Python #6

  Рет қаралды 154,037

codebasics

codebasics

Күн бұрын

Collisions in hash table can be handled using separate chaining or linear probing (also known as open addressing or closed hashing). We will cover these two techniques in this tutorial and then implement hash table class in python using separate chaining. Hash map or hash table is a very popular data structure. It allows to store key, value pairs and using key you can locate a value in O(1) or constant time.
Code: github.com/codebasics/data-st...
Exercise: github.com/codebasics/data-st...
Topics
00:00 Introduction
00:33 Separate chaining
02:37 Linear probing
03:42 Implement chaining in python
15:38 Exercise
Do you want to learn technology from me? Check codebasics.io/ for my affordable video courses.
#datastructures #algorithms #python #HashTable #HashTablealgorithms
Next Video: • Stack - Data Structure...
Previous video: • Hash Table - Data Stru...
Complete playlist: • Data Structures And Al...
Website: codebasics.io/
Facebook: / codebasicshub
Twitter: / codebasicshub

Пікірлер: 212
@codebasics
@codebasics 2 жыл бұрын
Do you want to learn python from me with a lot of interactive quizzes, and exercises? Here is my project-based python learning course: codebasics.io/courses/python-for-beginner-and-intermediate-learners
@Saurav061
@Saurav061 3 ай бұрын
Hey, while handling the collisions in __setitem__() function, "if len(element) == 2" why is this necessary? Timestamp : 7:42
@aashi9781
@aashi9781 2 жыл бұрын
Just started on the DSA journey combining practice with your guidance and taking notes. I started my Data science journey around 3n half years back and you were the first tutorial that I clicked for ML. I remember being so naive at that point but later on just got a flow out and got a chance to be a mature professional in data science field. Now feeling the urge for Targeting the Data Structure and Algorithms next!! Thank you so much! Enjoying it!
@anshulhedau10
@anshulhedau10 2 жыл бұрын
I have seen many videos but your videos have simplest explanation among all. Respect.
@ShashankData
@ShashankData 2 жыл бұрын
Amazing video! This was by far the clearest explanation of this I've ever seen!
@erenhan
@erenhan 2 жыл бұрын
this is the best practical exercise and explanation for hashtables for python in entire web, big thank you
@svetliodoychinov5580
@svetliodoychinov5580 Жыл бұрын
Amazing video! Best explantion I have found and the exercises are very useful I just finnished the nyc_weather one. Used the built in hash function and handles collisions by adding (key, value) tuples to a list that is on the index. Thank you for the great video!
@ozioma
@ozioma 3 жыл бұрын
sooo clear and concise!!
@brijpathak3873
@brijpathak3873 4 жыл бұрын
You're an excellent teacher, Dhaval. Thanks and hope your passion does a lot of good for you!
@hoatruong2474
@hoatruong2474 2 жыл бұрын
Best explanation and implementation of hash table ever, understand it immediately
@RajAryan
@RajAryan 3 ай бұрын
Even to this date your videos are the best on the entire youtube. Hats off to you!! Really enjoying learning DSA :)
@karrianilkumar8123
@karrianilkumar8123 2 жыл бұрын
You are a very good teacher. Thank you Mr Dhaval
@xidd1
@xidd1 3 жыл бұрын
This is actually a pretty good revision of the concepts too, thanks
@codebasics
@codebasics 3 жыл бұрын
glad you liked it
@pieropanariello8959
@pieropanariello8959 4 жыл бұрын
Thanks so much! Keep making these vids!
@heidik1757
@heidik1757 3 жыл бұрын
Took me a while to really get each of the steps but good video :)
@deepaksrinivasan8188
@deepaksrinivasan8188 3 жыл бұрын
@Codebasics, I could image why HashTables are your favorite data structures...:) Exercises done and moving onto Stack and Queues ! Just brilliant tutorials.:)
@Shourya_performs
@Shourya_performs 2 жыл бұрын
greatttttt. i wanted to ask a ques dictionary itself handles this collision??
@saisridhart3133
@saisridhart3133 2 жыл бұрын
@@Shourya_performs No bro dictionary overwrites the previous value with the current value
@Shourya_performs
@Shourya_performs 2 жыл бұрын
@@saisridhart3133 yes bro. Thnx
@VivekYadav-sy2ec
@VivekYadav-sy2ec 3 жыл бұрын
Sir your way of teaching is just excellent, god bless you!
@codebasics
@codebasics 3 жыл бұрын
Glad it was helpful!
@deepak-georgethomas3152
@deepak-georgethomas3152 3 жыл бұрын
This was really helpful. Thank you.
@user-np3rt6km9w
@user-np3rt6km9w 3 жыл бұрын
Thank you Sir, the exercises were very helpful!
@pazuzil
@pazuzil 4 жыл бұрын
Wow thanks so much. Your explanation was very clear
@AngelSanchez-fi7vf
@AngelSanchez-fi7vf 2 жыл бұрын
Great video. Thank you!
@leakyroofmedia
@leakyroofmedia 2 жыл бұрын
Great videos! Thank you!
@ningma1048
@ningma1048 2 ай бұрын
excellent explanation! thanks
@DispelTV
@DispelTV 2 жыл бұрын
Great videos, thank you so much! Do you have any projects that use these algorithms and data structures to help us imbed this information into our brains?
@pythonenthusiast9292
@pythonenthusiast9292 4 жыл бұрын
G.O.A.T you're my hero!!
@priyanshupurohit5431
@priyanshupurohit5431 Жыл бұрын
Thankyou sir i really apreciate your way of teaching
@johanlopez7452
@johanlopez7452 2 жыл бұрын
And here I am paying college tuition and students loans to "learn" what this awesome dude gives out for free. You are the best man, love your content.
@rupeshchoudhary9237
@rupeshchoudhary9237 3 жыл бұрын
Awesome videos. Thank so much for making such precise vidoes.
@codebasics
@codebasics 3 жыл бұрын
Glad you like them!
@NoobTube4148
@NoobTube4148 2 жыл бұрын
Would be nice if you could touch on double hashing and also explain what happens when hash table itself needs to grow or the individual slot data structure has to grow. What happens to the time complexities in those cases?
@alexrubio9507
@alexrubio9507 6 ай бұрын
You wrote this question one year ago, I don't know if my answer will help you anymore, but still I'm gonna answer it. However big a hash table/ hash map is gonna be, the time complexity will always be O(1), when talking about searching. The downside of hash tables is that if you need to store a huuuge amount of data, you need a pretty complex hash table and it will occupy a pretty big chunk of memory. The time complexity remains the same, though the *space complexity* will increase drastically.
@Rickyvidere
@Rickyvidere 3 жыл бұрын
I commend your channel and explanations. Very well put together thank you!
@codebasics
@codebasics 3 жыл бұрын
I appreciate that!
@acoustictuber2227
@acoustictuber2227 2 жыл бұрын
@@codebasics sir can u please tell is it oky fir me btech cse interviews. ?
@jayshreedonga2833
@jayshreedonga2833 Жыл бұрын
thanks nice session
@jykw1717
@jykw1717 3 жыл бұрын
Sir you're awesome. I subscribed and liked your videos. In the future please make videos on how to prepare for coding test and interviews and tech interviews for companies
@vasilijejukic9682
@vasilijejukic9682 3 жыл бұрын
Thanks ! I did 2 exercises by myself :) Soon going to Stack and Queue !
@codebasics
@codebasics 3 жыл бұрын
👍☺️ good job
@user-co6rg9jt9x
@user-co6rg9jt9x 3 жыл бұрын
Thank you so much
@abdullahanati2507
@abdullahanati2507 2 жыл бұрын
Great explanation! You can use for else in 8:45 min.
@apoorvshrivastava3544
@apoorvshrivastava3544 4 жыл бұрын
Sir Sunday aur morning dono good ho gaye
@asahoo550
@asahoo550 3 жыл бұрын
Can anybody explain since we found the length of tuple is 2 and key is present at 0th index in the list then why do we inserting second key, value pair on that particular index.... isn't it that going to replace the first one
@kamaleshajjarapu3259
@kamaleshajjarapu3259 3 жыл бұрын
Hi, In the below snippet of your Linear Probing code, "if element is None: return" line is not required as it may return None if previous element of the desired element is None while traversing. However it is not running in any case when prob_range (even though it returns you all indexes) is used. def __getitem__(self, key): h = self.get_hash(key) if self.arr[h] is None: return prob_range = self.get_prob_range(h) for prob_index in prob_range: element = self.arr[prob_index] if element is None: return if element[0] == key: return element[1] For better understanding, if I change the code as shown below , then it will return None if previous element is None before the desired element is executed. Eg: [('march 17', 30), ('march 163', 355), ('march 193', 455), ('march 443', 455), ('march 553', 455), ('march 123', 455), ('march 133', 355), None, None, ('march 6', 20)] Output: It returns None for ''march 6' def __getitem__(self, key): h = self.get_hash(key) if self.arr[h] is None: return ##prob_range = self.get_prob_range(h) for prob_index in range(len(self.arr)): #Change here element = self.arr[prob_index] if element is None: return None #Change here if element[0] == key: return element[1] Thanks
@sachinmaurya3259
@sachinmaurya3259 3 жыл бұрын
very informative
@codebasics
@codebasics 3 жыл бұрын
Glad it was helpful!
@zap7140
@zap7140 2 жыл бұрын
Thanks
@debasismondal3619
@debasismondal3619 2 жыл бұрын
Thanks a lot Dhaval, I have been learning a lot from you and using this skill to search for a career as a developer or data scientist after 10 years of administration experience, hope I will find a career soon! I did all the exercises by myself with your encouragement but I check your every solution as well. I found the solution for Linear Probing is not working as expected when I am running the following case t = HashTable() t["march 6"] = 20 t["march 17"] = 88 del t["march 6"] t['march 17'] However, both of the following is working fine def __getitem__(self, key): h = self.get_hash(key) prob_range = self.get_prob_range(h) for prob_index in prob_range: element = self.arr[prob_index] if element is None: continue if element[0] == key: return element[1] def __getitem__(self, key): h = self.get_hash(key) for i in range(self.MAX): element = self.arr[h] h = (h+1)%self.MAX if element == None: continue if element[0] == key: return element[1]
@siddharthsinghh
@siddharthsinghh 2 жыл бұрын
Room looks clean
@fluffyisyermom7631
@fluffyisyermom7631 5 ай бұрын
I'm actually just kind of confused after watching these last two videos. In linked lists you clearly helped us understand the structure of a linked list then asked us to modify what you wrote with our own functions. That was helpful. Here you showed us 50 minutes of hash functions and how to mess with lists(arrays) to store values and avoid collisions. Yet none of the excercises have anything to do with the videos themselves. > videos: I'm going to teach you how to cook a steak on your stove top exercise: now pull out some chicken so we can get started
@sumitkumarsah8782
@sumitkumarsah8782 4 жыл бұрын
Sir can you please make videos on dynamic programming...or can you please suggest some good channels from where i can follow.
@user-zn2hr3ci9z
@user-zn2hr3ci9z 2 жыл бұрын
great channel sir. Can you please make vedios on priority queue and heap data structure?
@abhinavreddy5350
@abhinavreddy5350 4 жыл бұрын
tq so much sir..................................... do more videos....
@codebasics
@codebasics 4 жыл бұрын
Sure.
@rahulgandhi4271
@rahulgandhi4271 4 жыл бұрын
why did you check the length of element in setitem method ?
@mandihaase2744
@mandihaase2744 4 жыл бұрын
Thank you so much for your video! How would you implement a rehash to resize the current hash table? Any suggestions you could provide would be greatly appreciated!
@cyborgoni
@cyborgoni 2 жыл бұрын
I second this. I'm going through this transactional data that needs data augmentation with hash function and what Mandi has requested, will help alot. Thanks!
@kartikeychhipa3813
@kartikeychhipa3813 3 жыл бұрын
hey if anyone having a problem understanding for loop in this program try printing idx , element, h in after if statement and append statement
@CHAN-xn9eq
@CHAN-xn9eq 2 жыл бұрын
in Enumerate function we are not passing the entire array only the element of array ... that is the list of key value pairs of that particular element
@poornimaumapathy9986
@poornimaumapathy9986 2 жыл бұрын
Crisp and clear tutorial for hash maps sir.Thank you. Could you please explain why if len(element) ==2 is checked in setitem function
@sachinbisht4368
@sachinbisht4368 2 жыл бұрын
It was done because your element is a (key,value) pair so the len has to be 2 for that. Though I think the code will run smoothly without that.
@sachinbisht4368
@sachinbisht4368 2 жыл бұрын
h = self.gethash(key) key_exists = False slot = self.arr[h] #making a dynamic array to store collisions. for index, kv in enumerate(slot): #here Searching if the key already exists or not. k, v = kv #splitting the key and value pair if key == k: #if it matches the already existing key then insert it in the next slot. key_exists = True break if key_exists: #THIS IS TO UPDATE THE VALUE of same key. slot[index] =((key, value)) else: slot.append((key, value))
@KANISHKSAHUSIME
@KANISHKSAHUSIME 2 жыл бұрын
hello sir instead of using for loop directly if we check number of elements present in each list then going to for loop will it decrease the time complexity?
@vigneshm7462
@vigneshm7462 3 жыл бұрын
Which hash function does dictionary implements behind is it linear probing or chaining using list
@zd676
@zd676 3 жыл бұрын
Great video! However I do have a confusion as you call a list of tuples as linked list in the video. Shouldn't it be just an array of tuples? Since these tuples are not really linked in anyway. I mean if I want to insert another tuple or delete one tuple, the time complexity here is O(n), where as it should be O(1) for linked list, correct?
@assarlannerborn9342
@assarlannerborn9342 3 жыл бұрын
Yes i am also confused
@SwagatSusmoy
@SwagatSusmoy 3 жыл бұрын
Hey man Excellent explanation and am studying from your videos right now I just found one small error in the hash table with linear probing solution We know according to our hash function 'march 6' and 'march 17' give the same value ie. 9 Now when using probing once we insert the value of march 6 followed by march 17 and if we delete the value for march 6 then calling for the value of march 17 returns none as while checking for the hash index it finds the index empty and returns none. Would love it if you could correct it as to how to get around this problem. Thanks a lot for the videos and seeing this in advance
@ashaypatil
@ashaypatil 2 жыл бұрын
def __delitem__(self, key): h = self.get_hash(key) for idx, k in enumerate(self.arr[h]): if k[0] == key: self.arr[h].remove(self.arr[h][idx])
@AdityaGupta-xp7ov
@AdityaGupta-xp7ov 4 ай бұрын
Can't we use hash function which is readily available and gives the unique hash value for every input so we won't be needing chaining and there won't be any case where the index of two or more different keys will be matching with each other.
@TheBhartiyaTrainee
@TheBhartiyaTrainee 2 жыл бұрын
Let me take the chance to click the 1000th like!! Do we have to manually deal with csv files or can the third party/standard lib modules be used?
@codebasics
@codebasics 2 жыл бұрын
well csv files can be read and analyzed easily using a python module called pandas
@tanyipeng3440
@tanyipeng3440 3 жыл бұрын
Why is the hashtable in python implement as nested list however , other languages use a array that is linked with linked list to store data that has collisions?
@adbuth4854
@adbuth4854 2 жыл бұрын
hello sir, what does the idx represents while iterating through the llist
@paulclouseau7998
@paulclouseau7998 3 жыл бұрын
for adding elements to the linked list just do append method, you dont need to do the enumerate loop and the found check
@paulclouseau7998
@paulclouseau7998 3 жыл бұрын
I thinkkkkkkk.... :(((((
@codebasics
@codebasics 3 жыл бұрын
You need to do find check. Else if some one is updating a value at a given key it won't work
@LtMewS
@LtMewS 4 жыл бұрын
Is that linked Liston separate chaining or usual 2d array
@akshaynitin5589
@akshaynitin5589 20 күн бұрын
i have doubt, for this setitem, getitem, delitem, still we are dependent on O(n). but how we are telling this o(1) ?
@SARATHBABU-ni4pt
@SARATHBABU-ni4pt Ай бұрын
Can you explain linearprobing imlementation same way??
@prithvijali2629
@prithvijali2629 2 жыл бұрын
Hi i have a question here, to avoid collision we can resize the hashtable or increment it by one. So that we can get different hash values if there are any collisions. Is it possible to change the size of hashtable dynamically?
@davejenil1537
@davejenil1537 2 жыл бұрын
yes possible but again problem of re-allocation if you try to insert beyond the capacity
@myrusEW
@myrusEW 11 ай бұрын
This one was tough. Lot of moving parts for me. bout to get started on these problems
@myrusEW
@myrusEW 10 ай бұрын
i finally completed the exercises. kind of annoyed that you just used a dictionary in the solution. i reimplemented an entire hashtable class with custom methods for them...like in the video. i had so many issues with the overall logic and making it solid. I had to figure out so many things..hah. i feel so dumb and like i wasted so much time
@chuanzong7904
@chuanzong7904 3 жыл бұрын
for the setitem function, is the 'len(element) == 2 ' necessary? the every element in the linklist is the key-value pair, therefore it must be 2?
@jimyi2305
@jimyi2305 3 жыл бұрын
yea i also didnt get it can someone explain?
@ultronhack8151
@ultronhack8151 3 жыл бұрын
Its not required
@likhithdasari7794
@likhithdasari7794 3 жыл бұрын
yeah it may not be useful
@sourabhwadhwa05
@sourabhwadhwa05 3 жыл бұрын
I have one question, lets say we have three columns in an excel and i want to print the third column value on the basis of two columns as key. Ex: ice and cream keys give value “ice-cream trucks” another ex: ice and water gives “cold water” as value another ex: water and cream gives “yuck taste” as value , assume this in a excel and i want to display ice cream truck or yuck water or cold water on the basis of two key inputs how can i do that!!
@meralmaradia4774
@meralmaradia4774 2 жыл бұрын
Hello Sir, can you please create a video developing of project using only DSA ?
@abhi-_-
@abhi-_- 3 жыл бұрын
what would be different if a dictionary was used in place of a simple list for chaining
@dikshantmadaan9116
@dikshantmadaan9116 Жыл бұрын
I am using following function: def add(key, val): hash_value = get_hash(key) d[hash_value].append((key, val)) instead of your __setitem__() function and still my code is working fine, and I don't understand why? and when I am using your __setitem__(), I am getting an error on the following line: self.arr[h][idx] = (key,val)
@yashpreetkaur2042
@yashpreetkaur2042 2 жыл бұрын
I understood the video well but the exercises are like made me feel am I really understanding. Please someone help me to choose the right path, do I need to go for learning advanced python side by side?
@vidhansaini9296
@vidhansaini9296 11 күн бұрын
is this implementation is just for explaning the concept of hash table or it's practical cause why make thing when we already have dictionary and other data structures working like a hash table.
@maggiezhang145
@maggiezhang145 2 жыл бұрын
How come I don't see a Linked List? I only see the array was used in the collision place?
@shubhz.sayzzz
@shubhz.sayzzz 3 жыл бұрын
Instead of appending (key, value) tuple, can we append a list [key,value]? What changes will it make?
@usamanadeem8504
@usamanadeem8504 3 жыл бұрын
bruh first thing you should know is that we can't update a tuple so, he was not appending tuple he was appending list!!!
@nelsonberm3910
@nelsonberm3910 Ай бұрын
love u
@debasmitachoudhury7398
@debasmitachoudhury7398 3 жыл бұрын
Sir, your video was of great help. Thank you. However, I have a doubt it would be helpful if you please clarify it. In chaining as said in video linked list is used. As I know every node in LL has a head and a next. So, if LL is used here then don't we have to use head and next in set and del methods? or simple list has been used here?
@codebasics
@codebasics 3 жыл бұрын
In python a simple list is a dynamic array. One can use dynamic array as well in place of a linked list. In previous tutorials I have mentioned difference between dynamic and static array. Please go through that.
@GeorgeNyamao
@GeorgeNyamao 3 жыл бұрын
A simple list is sufficient for chaining. I suspect chaining is used to show various ways of avoiding collision. This is the brute force solution. Then we go to better rehashing solutions like linear probing, quadratic probing, and eventually using the python built-in hashtable.
@ashaypatil
@ashaypatil 2 жыл бұрын
Could someone please tell me why are we not appending the key value pair whenever we find key to be already present. We should append the key value pair to that element, isn't it? def __setitem__(self, key, value): h = self.get_hash(key) found = False # if key exists already then append the value to the key for idx, k in enumerate(self.arr[h]): if len(k) == 2 and k[0] == key: self.arr[h].append((key, value)) found = True break # if the key value pair doesn't exist, add the key and value if not found: self.arr[h].append((key, value))
@ducanhnguyen6903
@ducanhnguyen6903 Жыл бұрын
You said "chaining" is using linked list; but I only see adding tuples to a list. Where is the linked list? Am I missing something? Thanks!
@guptalovelymananishu
@guptalovelymananishu 4 жыл бұрын
Dhaval aap apni har video mai bol diya kijiye ki apka hindi channel bhi hai jo hindi mai comfortable hai woh bhi same benefits le sakta hai . Yeh ek request hai na ki salah. You are doing great job.
@codebasics
@codebasics 4 жыл бұрын
Sure neha but I don't have many tutorials on Hindi channel. That's why I am not highlighting
@gloryasuquo5043
@gloryasuquo5043 4 жыл бұрын
Hello Sir. Thank you so much for your videos, it has really been of help. I have just worked on the linear probing exercise and my solution is a little different from yours but it does what its suppose to do. I was hoping you could look into mine and comment on it, if it's right and why you didn't work it this way. class HashTable: def __init__(self): self.MAX = 10 self.arr = [None for i in range(self.MAX)] def get_hash(self, key): h = 0 for char in key: h += ord(char) return h % self.MAX def __setitem__(self, key, value): h = self.get_hash(key) if self.arr[h] is None: self.arr[h] = (key, value) else: empty_space = self.arr.index(None) # index() finds the first occurrence of an empty space self.arr[empty_space] = (key, value) def __getitem__(self, key): h = self.get_hash(key) return self.arr[h] h = HashTable() h['march 6'] = 130 h['march 7'] = 78 h['march 8'] = 210 h['march 9'] = 530 h['march 17'] = 28 print(h.arr) print(h['march 7']) Thank you very much sir. I look forward to your reply.
@akashvshroff
@akashvshroff 4 жыл бұрын
Hey, so when you manually modify your index position based on whichever the closest empty space is, you only do that in the setitem method and there is no conceivable way to calculate this changed index in the delitem and getitem methods so you end up with the wrong answer! For example: suppose you have an array the size of 5, and 2 keys: 'x' and 'y' which give you the same index 2. First when the array is empty, you add the value associated with 'x', say 'foo', at index 2. Now when you try to add 'boo' associated with key 'y', you get the same index 2 but then you see that it is not empty and so you add it at index 0. Now your hash function doesn't know that you've changed the index for the key 'y' to 0 and so when the user tries accessing the hash table with ['y'], the index that the function getitem receives is still 2 and so it returns the value of key 'x' instead of key 'y', thereby returning 'foo' instead of 'boo'! I hope this helped :)
@debasmitachoudhury7398
@debasmitachoudhury7398 3 жыл бұрын
@@akashvshroff HI.. can you kindly help in my doubt. In chaining as said in video linked list is used. As I know every node in LL has a head and a next. So, if LL is used here then don't we have to use head and next in set and del methods? or simple list has been used here?
@akashvshroff
@akashvshroff 3 жыл бұрын
@@debasmitachoudhury7398 Hey, so you could use your linked list and do that but here to make the implementation slightly easier to understand and for simplicity in code, a python list has been used. Moreover, unlike other languages, a python list is dynamic which means that it can be extended with no initial size and so it seems fitting for this scenario :)
@jerrygeorge180
@jerrygeorge180 2 жыл бұрын
@@debasmitachoudhury7398 a simple list have been used
@rrvv01
@rrvv01 3 жыл бұрын
Keys 'march 9' and 'march 10' has the same h, but are different keys, how do we deal with that. Thanks :-)
@syamkumarpujala5736
@syamkumarpujala5736 3 жыл бұрын
linear probing: class HashTable: def __init__(self): self.MAX = 10 self.arr = [(None,None) for i in range(self.MAX)] def get_hash(self, key): hash = 0 for char in key: hash += ord(char) return hash % self.MAX def __getitem__(self, index): h = self.get_hash(index) found=False if self.arr[h][0]==index: return self.arr[h][1] else: for idx,element in enumerate(self.arr[h+1:]+self.arr[:h-1]): if element[0] == index: return element[1] return self.arr[h] def __setitem__(self, key, val): h = self.get_hash(key) set = False for idx,element in enumerate(self.arr): if idx==h and element[0]!=None: for i,j in enumerate(self.arr[idx+1:]+self.arr[:idx-1]): if j[0]==None: self.arr[i]=(key, val) set=True break if not set: self.arr[h] = (key, val)
@priyankashelke7694
@priyankashelke7694 2 жыл бұрын
Thanks for the great explanation......but I'm getting h value for 'march 6' and 'march 17' is different that is 9 and 59 ...so how to resolve this issue?
@somilagrawal8172
@somilagrawal8172 Жыл бұрын
It's bcz you are using mod 100(means a 100 length array) but he is(in this video) using mod 10( reduced the array size to 10). In case you don't understand mod function here is used to make sure that our no.(index in this case) stays within our defined range.
@massefromla2554
@massefromla2554 11 ай бұрын
I can not find your exercises anywhere on-site . No Datastructure folder . Where are .cvs files .
@deeprajmazumder6261
@deeprajmazumder6261 2 жыл бұрын
can anyone explain whats happening in 7:51
@sanjays395
@sanjays395 3 жыл бұрын
The case where all the locations are filled in #LinearProbing i.e., 10 elements are filled according to the example what we need to do?
@murariteja4909
@murariteja4909 3 жыл бұрын
yes i also got that doubt
@HarshSingh-lp5xo
@HarshSingh-lp5xo 3 жыл бұрын
sir, I have a doubt !!! why you saying that list as link-list at index h, as it is working as a list, not link-list.
@vrushaliprakashsalvi6167
@vrushaliprakashsalvi6167 2 жыл бұрын
@codebasics same doubt here!!
@siddharthsinghh
@siddharthsinghh 2 жыл бұрын
@@vrushaliprakashsalvi6167 same here also
@TKZntkx
@TKZntkx Жыл бұрын
__setitem__ has a bug on python 3.11.0, the value cannot be set
@swaniketchowdhury
@swaniketchowdhury 3 жыл бұрын
Just a quick question: If Collision Handling methods make the search runtime go up to O(n), then is it really worth it to use hashmaps in the first place? I believe the lookup time also won't be constant time, it should be a linear time in the worst case.... Correct me if I'm wrong!
@thammayyaarava2259
@thammayyaarava2259 2 жыл бұрын
Yeah it will be in the first place if we wrote an efficient hash function..
@TK-vt3ep
@TK-vt3ep 4 жыл бұрын
Hello Sir, Since we already we have dict handy in python, then why we exactly use hashmap? Please help me to understand. Is it just to get to know how dict works
@codebasics
@codebasics 4 жыл бұрын
Yes. It is just to understand how dict works internally 👍😊
@sezermezgil9304
@sezermezgil9304 3 жыл бұрын
Hi how do i download the files for exercises
@Tenacioustarantula
@Tenacioustarantula 3 жыл бұрын
Isn't the following incorrect?it always replaces the tuple in index 0 and it doesn't append
@saiyedali561
@saiyedali561 4 жыл бұрын
def get_prob_range(self, index): return [*range(index, len(self.arr))] + [*range(0,index)] please Explain it
@nicolassanchez8182
@nicolassanchez8182 Ай бұрын
Small correction: You meant to say (single) list instead of linked list.
@chandannooli9218
@chandannooli9218 3 жыл бұрын
My IDLE compiler is asking me to define f
@nityanandk5522
@nityanandk5522 3 жыл бұрын
why the len(element) == 2 condition in the __setitem__ function
@KarinaRodriguez-yv7mf
@KarinaRodriguez-yv7mf 3 жыл бұрын
I had the same question: I think its because if you notice he initiates the array as a list of empty lists. Python will return true to the if -statement in question for an empty list but we only want it to return true if there exist a tuple at each element in linked list. Seems to me hes being overcautious for the case that someone does want to insert an empty list as the key to a specific value.
@nityanandk5522
@nityanandk5522 2 жыл бұрын
@@KarinaRodriguez-yv7mf its tuple of two elements ie key and value that's why len(element)==2
@saramsasherchan3731
@saramsasherchan3731 3 жыл бұрын
Sir i am getting march 17 hash as 59 is it wrong or its related ASCII code according to any other configuration of the computer system
@vishwas2764
@vishwas2764 3 жыл бұрын
Try using "July 18" and "July 27" it worked out for me!
@pup_lover
@pup_lover 2 жыл бұрын
@@vishwas2764 thx! you found it out by trial and error? because it would take a long time to find 2 keys with same hash values
@DiasDenny
@DiasDenny 4 жыл бұрын
Sir,I have a doubt.Suppose all the elements got collided .Won't it append all the elements in a single array and therefore Won't the searching time be o(n)
@codebasics
@codebasics 4 жыл бұрын
It can happen. And for that reason your hash function should be designed in a way that it can distribute elements equally among all buckets
@mahmoudgadelrab5133
@mahmoudgadelrab5133 2 ай бұрын
Nobel prize
@jaheerkalanthar816
@jaheerkalanthar816 3 жыл бұрын
please can anyone explain,what is the line means def get_prob_range(self, index): return [*range(index, len(self.arr))] + [*range(0,index)]
@alexdeathway
@alexdeathway 3 жыл бұрын
It return list of all number from index to end + start to index. for example your element key is 7 and hashmap length is 10, then this code will return [7, 8, 9, 10, 0, 1, 2, 3, 4, 5] Now this list can be used for iteration.
@55mayakeren55
@55mayakeren55 Жыл бұрын
why not using dict element in the self.arr instead of linked lists?
@anuvind_m
@anuvind_m Жыл бұрын
Python dictionary works on the idea of hash table. Here we are building our own version of dictionary. So, using python's inbuilt dictionary to create a user defined dictionary makes no sense. I know your comment is from 9 months ago, may my comment be useful for upcoming viewers.
Stack - Data Structures & Algorithms Tutorial In Python #7
13:05
codebasics
Рет қаралды 221 М.
Hash Tables and Hash Functions
13:56
Computer Science
Рет қаралды 1,5 МЛН
Каха и суп
00:39
К-Media
Рет қаралды 5 МЛН
100❤️
00:19
MY💝No War🤝
Рет қаралды 22 МЛН
ПРОВЕРИЛ АРБУЗЫ #shorts
00:34
Паша Осадчий
Рет қаралды 1,6 МЛН
Hash Table - Data Structures & Algorithms Tutorials In Python #5
17:52
How I Got Good at Coding Interviews
6:29
NeetCode
Рет қаралды 1,6 МЛН
I gave 127 interviews. Top 5 Algorithms they asked me.
8:36
Sahil & Sarra
Рет қаралды 620 М.
Python Hash Sets Explained & Demonstrated - Computerphile
18:39
Computerphile
Рет қаралды 111 М.
Why I Chose Rust Over Zig
33:18
ThePrimeTime
Рет қаралды 48 М.
Learn Hash Tables in 13 minutes #️⃣
13:26
Bro Code
Рет қаралды 330 М.
Каха и суп
00:39
К-Media
Рет қаралды 5 МЛН