Rebuild the  Map ADTs structure given below with the Linked list method. Include the remove, add, contains, len, show and iter methods. Please use the python language. 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

Database System Concepts
7th Edition
ISBN:9780078022159
Author:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Chapter1: Introduction
Section: Chapter Questions
Problem 1PE
icon
Related questions
Question

Rebuild the  Map ADTs structure given below with the Linked list method. Include the remove, add, contains, len, show and iter methods. Please use the python language.

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
steps

Step by step

Solved in 2 steps

Blurred answer
Knowledge Booster
Operations of Linked List
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
Database System Concepts
Database System Concepts
Computer Science
ISBN:
9780078022159
Author:
Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:
McGraw-Hill Education
Starting Out with Python (4th Edition)
Starting Out with Python (4th Edition)
Computer Science
ISBN:
9780134444321
Author:
Tony Gaddis
Publisher:
PEARSON
Digital Fundamentals (11th Edition)
Digital Fundamentals (11th Edition)
Computer Science
ISBN:
9780132737968
Author:
Thomas L. Floyd
Publisher:
PEARSON
C How to Program (8th Edition)
C How to Program (8th Edition)
Computer Science
ISBN:
9780133976892
Author:
Paul J. Deitel, Harvey Deitel
Publisher:
PEARSON
Database Systems: Design, Implementation, & Manag…
Database Systems: Design, Implementation, & Manag…
Computer Science
ISBN:
9781337627900
Author:
Carlos Coronel, Steven Morris
Publisher:
Cengage Learning
Programmable Logic Controllers
Programmable Logic Controllers
Computer Science
ISBN:
9780073373843
Author:
Frank D. Petruzella
Publisher:
McGraw-Hill Education