CODING A MAP ADT USING LINKED LIST IN PYTHON. Rebuild the given Map ADTs structure with the Linked list method using the python language. It should include the remove, add, contains, len, show and iter methods. The add method, should be arranged to add both to the beginning and the end.  class Map: def __init__(self): self._entryList = list()#empty list initialization def __len__(self): return len(self._entryList) def __contains__(self, key): ndx = self._findPosition(key) return ndx is not None #adds a new entry, or replace value if exists def add(self, key, value): ndx = self._findPosition(key) if ndx is not None: #key found self._entryList[ndx].value = value return False else: entry = _MapEntry(key,value) self._entryList.append(entry) return True def valueOf(self, key):#what value this key holds ndx = self._findPosition(key) assert ndx is not None, "Invalid map key" return self._entryList[ndx].value def remove(self, key): ndx = self._findPosition(key) assert ndx is not None, "Invalid map key" self._entryList.pop(ndx) def __iter__(self): return _MapIterator(self._entryList) #helper method - so private def _findPosition(self, key): for i in range(len(self)): if self._entryList[i].key == key: return i else: return None #check if key in ith element, returns None otherwise class _MapEntry: def __init__(self, key, value): self.key = key self.value = value class _MapIterator: def __init__(self, entryList): self._entryList = entryList self._index = 0 def __iter__(self): return self def __next__(self): if self._index < len(self._entryList): element = self._entryList[self._index] self._index += 1 return element else: raise StopIteration

C++ Programming: From Problem Analysis to Program Design
8th Edition
ISBN:9781337102087
Author:D. S. Malik
Publisher:D. S. Malik
Chapter18: Stacks And Queues
Section: Chapter Questions
Problem 16SA
icon
Related questions
Question

CODING A MAP ADT USING LINKED LIST IN PYTHON. Rebuild the given Map ADTs structure with the Linked list method using the python language. It should include the remove, add, contains, len, show and iter methods. The add method, should be arranged to add both to the beginning and the end. 

class Map:
def __init__(self):
self._entryList = list()#empty list initialization

def __len__(self):
return len(self._entryList)

def __contains__(self, key):
ndx = self._findPosition(key)
return ndx is not None

#adds a new entry, or replace value if exists
def add(self, key, value):
ndx = self._findPosition(key)
if ndx is not None: #key found
self._entryList[ndx].value = value
return False
else:
entry = _MapEntry(key,value)
self._entryList.append(entry)
return True

def valueOf(self, key):#what value this key holds
ndx = self._findPosition(key)
assert ndx is not None, "Invalid map key"
return self._entryList[ndx].value

def remove(self, key):
ndx = self._findPosition(key)
assert ndx is not None, "Invalid map key"
self._entryList.pop(ndx)

def __iter__(self):
return _MapIterator(self._entryList)

#helper method - so private
def _findPosition(self, key):
for i in range(len(self)):
if self._entryList[i].key == key:
return i
else:
return None #check if key in ith element, returns None otherwise

class _MapEntry:
def __init__(self, key, value):
self.key = key
self.value = value

class _MapIterator:
def __init__(self, entryList):
self._entryList = entryList
self._index = 0

def __iter__(self):
return self

def __next__(self):
if self._index < len(self._entryList):
element = self._entryList[self._index]
self._index += 1
return element
else:
raise StopIteration

Expert Solution
trending now

Trending now

This is a popular solution!

steps

Step by step

Solved in 3 steps with 1 images

Blurred answer
Knowledge Booster
Problems on Amortized Analysis
Learn more about
Need a deep-dive on the concept behind this application? Look no further. Learn more about this topic, computer-science and related others by exploring similar questions and additional content below.
Similar questions
  • SEE MORE QUESTIONS
Recommended textbooks for you
C++ Programming: From Problem Analysis to Program…
C++ Programming: From Problem Analysis to Program…
Computer Science
ISBN:
9781337102087
Author:
D. S. Malik
Publisher:
Cengage Learning