Передняя команда дает себе идиому
Это код lec4 и данный код соответственно:
# non-mutable; persistent linked lists; also a stack
# immutable collections are much easier to use concurrently
#
# NOTE: There are no assignments to self.tail after its initialization
#
class EmptyListE :
def __str__(self) :
return "Exception: list is empty"
class NotFoundE :
def __str__(self) :
return "Exception: element not found"
class IndexOutOfBoundsE :
def __str__(self) :
return "Exception: index out of bounds"
#---
class List :
"""Non-mutable persistent lists
>>> xs = EmptyList().add(1).add(2).add(3).add(4)
>>> print xs
4, 3, 2, 1, []
>>> ys = xs.append(100)
>>> print ys
4, 3, 2, 1, 100, []
>>> print xs
4, 3, 2, 1, []
"""
def size (self) :
"""O(n).
Returns the number of elements in the current list.
>>> EmptyList().size()
0
>>> EmptyList().add(1).add(2).add(3).size()
3
"""
pass
def isEmpty (self) :
"""O(1).
Returns True or False depending on whether the current list is empty or not.
>>> EmptyList().isEmpty()
True
>>> EmptyList().add(1).add(2).add(3).isEmpty()
False
"""
pass
def search (self, v) :
"""O(n).
Returns True or False depending on whether 'v' occurs in the current list or not.
>>> EmptyList().search(1)
False
>>> EmptyList().add(1).add(2).add(3).search(2)
True
>>> EmptyList().add(1).add(2).add(3).search(100)
False
"""
pass
def elem (self, i) :
"""O(n).
Returns the element at zero-based index 'i' in the current list. If 'i' is out
of bounds, raises an exception.
>>> try :
... EmptyList().elem(0)
... except IndexOutOfBoundsE as e :
... print e
...
Exception: index out of bounds
>>> try :
... EmptyList().add(1).add(2).add(3).elem(10)
... except IndexOutOfBoundsE as e :
... print e
...
Exception: index out of bounds
>>> EmptyList().add(1).add(2).add(3).elem(0)
3
>>> EmptyList().add(1).add(2).add(3).elem(1)
2
>>> EmptyList().add(1).add(2).add(3).elem(2)
1
"""
pass
def index (self, v) :
"""O(n).
Returns the zero-based index of the first occurrence of 'v' in the current
list. If 'v' does not occur in the list, raises NotFoundE exception.
>>> try :
... EmptyList().index(1)
... except NotFoundE :
... print 'Not found'
...
Not found
>>> EmptyList().add(1).add(2).add(3).index(3)
0
>>> EmptyList().add(1).add(2).add(3).index(2)
1
>>> EmptyList().add(1).add(2).add(3).index(1)
2
>>> try :
... EmptyList().add(1).add(2).add(3).index(10)
... except NotFoundE :
... print 'Not found'
...
Not found
"""
pass
def insert(self, i, v) :
"""O(n).
Inserts 'v' at the given zero-based index 'i'. If the index i is too large,
throw IndexOutOfBoundsE exception.
>>> str (EmptyList().insert(0,5))
'5, []'
>>> try :
... EmptyList().insert(100,5)
... except IndexOutOfBoundsE as e :
... print e
...
Exception: index out of bounds
>>> str (EmptyList().add(1).add(2).add(3).insert(0,100))
'100, 3, 2, 1, []'
>>> str (EmptyList().add(1).add(2).add(3).insert(1,100))
'3, 100, 2, 1, []'
>>> str (EmptyList().add(1).add(2).add(3).insert(2,100))
'3, 2, 100, 1, []'
>>> str (EmptyList().add(1).add(2).add(3).insert(3,100))
'3, 2, 1, 100, []'
>>> try :
... str (EmptyList().add(1).add(2).add(3).insert(4,100))
... except IndexOutOfBoundsE as e :
... print e
...
Exception: index out of bounds
"""
pass
def remove(self,v) :
"""O(n).
Remove the first occurrence (if any) of 'v' from the current list.
>>> str(EmptyList().remove(10))
'[]'
>>> str(EmptyList().add(1).add(2).add(3).remove(2))
'3, 1, []'
>>> str(EmptyList().add(2).add(2).add(3).remove(2))
'3, 2, []'
"""
pass
def append(self,v) :
"""O(n).
Inserts 'v' at the end of the current list.
>>> str(EmptyList().append(10))
'10, []'
>>> str(EmptyList().add(1).add(2).add(3).append(10))
'3, 2, 1, 10, []'
>>> xs = EmptyList().add(1).add(2).add(3)
>>> print xs
3, 2, 1, []
>>> print xs.append(10)
3, 2, 1, 10, []
>>> print xs
3, 2, 1, []
"""
pass
def drop(self,i) :
"""Drops the first 'i' elements and returns the remaining list; raises an
exception if the index is too large.
>>> xs = EmptyList().add(1).add(2).add(3).add(4)
>>> print xs.drop(0)
4, 3, 2, 1, []
>>> print xs.drop(1)
3, 2, 1, []
>>> print xs.drop(2)
2, 1, []
>>> print xs.drop(3)
1, []
>>> print xs.drop(4)
[]
>>> try :
... xs.drop(5)
... except IndexOutOfBoundsE as e :
... print e
...
Exception: index out of bounds
"""
pass
def add(self,v) :
"""O(1).
Inserts 'v' at the front of the list.
>>> str(EmptyList().add(1).add(2).add(3))
'3, 2, 1, []'
"""
return Node(v,self)
def __iter__ (self) :
"""Creates an iterator.
>>> it = iter(EmptyList().add(1).add(2).add(3))
>>> it.next()
3
>>> it.next()
2
>>> it.next()
1
>>> try :
... it.next()
... except StopIteration :
... print 'Done'
...
Done
>>> for i in EmptyList().add(1).add(2).add(3) :
... print i
...
3
2
1
>>> [ i * i for i in EmptyList().add(1).add(2).add(3) ]
[9, 4, 1]
"""
return ListIterator(self)
#---
class EmptyList (List) :
def size (self) :
return 0
def isEmpty (self) :
return True
def search (self, v) :
return False
def elem (self, i) :
raise IndexOutOfBoundsE()
def index (self, v) :
raise NotFoundE()
def insert(self, i, v) :
if i == 0 :
return Node(v,self)
else :
raise IndexOutOfBoundsE()
def remove(self,v) :
return self
def append(self,v) :
return Node(v,self)
def drop(self,i) :
if i == 0 :
return self
else :
raise IndexOutOfBoundsE()
def __str__ (self) :
return "[]"
#---
class Node (List) :
def __init__ (self, head, tail) :
self.head = head
self.tail = tail
def size (self) :
return 1 + self.tail.size()
def isEmpty (self) :
return False
def search (self, v) :
return self.head == v or self.tail.search(v)
def elem (self, i) :
if i == 0 :
return self.head
else :
return self.tail.elem(i-1)
def index (self, v) :
if self.head == v :
return 0
else :
return 1 + self.tail.index(v)
def insert(self, i, v) :
if i == 0 :
return Node(v,self)
else :
return Node(self.head,self.tail.insert(i-1,v))
def remove(self,v) :
if self.head == v :
return self.tail
else :
return Node(self.head,self.tail.remove(v))
def append(self,v) :
return Node(self.head,self.tail.append(v))
def drop (self,i) :
if i == 0 :
return self
else :
return self.tail.drop(i-1)
def __str__ (self) :
return "%s, %s" % (self.head, self.tail)
#---
class ListIterator :
def __init__(self,list) :
self.list = list
def next(self) :
if self.list.isEmpty() :
raise StopIteration
else :
v = self.list.head
self.list = self.list.tail
return v
#-----------------------------------------------------------------------------
if __name__ == "__main__" :
import doctest
doctest.testmod()
Конец lec4.py
from lec4 import *
class MutableList :
"""Mutable lists. We maintain a pointer 'front' to a list and use DELEGATION
for read-only operations. Operations that change the list are implemented by
explicit pointer manipulations that update 'front' or self.tail for the relevant
node in the list.
"""
def __init__ (self) :
self.front = EmptyList()
#- easy delegations
def search (self,v) :
"""Returns True or False depending on whether 'v' occurs in the current list or not.
>>> xs = MutableList()
>>> xs.search(1)
False
>>> xs.add(1)
>>> xs.add(2)
>>> xs.add(3)
>>> xs.add(4)
>>> xs.search(2)
True
>>> xs.search(10)
False
"""
#your code goes here
if self.front.isEmpty(self) :
return False
elif !self.front.isEmpty(self) :
return self.front.search(v)
else :
return True
#end of your code
return self.front.search(v)
def isEmpty (self) :
"""Returns True or False depending on whether the current list is empty or not.
>>> xs = MutableList()
>>> xs.isEmpty()
True
>>> xs.add(1)
>>> xs.isEmpty()
False
"""
#your code goes here
if self.front == None : #looks for no elements
return True
else : #an element exists
return False
#code ends here
pass
Код, который я использовал для попытки:
if self.front == None : #looks for no elements
return True
else : #an element exists
return False
pass
Я просмотрел https://docs.python.org/2/tutorial/classes.html и https://docs.python.org/2/tutorial/datastructures.html и не нашел ничего о передней фразеологии. Я не уверен в точной функции и что она делает. Если бы кто-то мог объяснить, что именно делает фронт и его декларация возврата, если он есть.
Когда я делаю отладчик, он говорит, что ничего не возвращает, то есть даже не вводит оператор if. Почему это говорит это?
1 ответ
Все, что мне нужно было сделать, это получить доступ к функции isEmpty() из класса Node.
Спасибо за помощь, хотя.