Merge pull request #37 from ShyamW/master

Merge Request
This commit is contained in:
Chetan Kaushik 2016-10-09 21:56:22 +05:30 committed by GitHub
commit 101cccd14b
4 changed files with 62 additions and 4 deletions

View File

@ -4,13 +4,17 @@ class Queue():
self.entries = [] self.entries = []
self.length = 0 self.length = 0
def __str__(self):
printed = '<' + str(self.entries)[1:-1] + '>'
return printed
"""Enqueues {@code item} """Enqueues {@code item}
@param item @param item
item to enqueue""" item to enqueue"""
def put(self, item): def put(self, item):
self.entries.append(item) self.entries.append(item)
self.length = self.length + 1 self.length = self.length + 1
print(self.entries)
"""Dequeues {@code item} """Dequeues {@code item}
@requirement: |self.length| > 0 @requirement: |self.length| > 0
@ -22,6 +26,13 @@ class Queue():
self.entries = self.entries[1:] self.entries = self.entries[1:]
return dequeued return dequeued
"""Rotates the queue {@code rotation} times
@param rotation
number of times to rotate queue"""
def rotate(self, rotation):
for i in range(rotation):
self.put(self.get())
"""Enqueues {@code item} """Enqueues {@code item}
@return item at front of self.entries""" @return item at front of self.entries"""
def front(self): def front(self):
@ -30,6 +41,3 @@ class Queue():
"""Returns the length of this.entries""" """Returns the length of this.entries"""
def size(self): def size(self):
return self.length return self.length

View File

@ -0,0 +1,50 @@
"""Queue represented by a pseudo stack (represented by a list with pop and append)"""
class Queue():
def __init__(self):
self.stack = []
self.length = 0
def __str__(self):
printed = '<' + str(self.stack)[1:-1] + '>'
return printed
"""Enqueues {@code item}
@param item
item to enqueue"""
def put(self, item):
self.stack.append(item)
self.length = self.length + 1
"""Dequeues {@code item}
@requirement: |self.length| > 0
@return dequeued
item that was dequeued"""
def get(self):
self.rotate(1)
dequeued = self.stack[self.length-1]
self.stack = self.stack[:-1]
self.rotate(self.length-1)
self.length = self.length -1
return dequeued
"""Rotates the queue {@code rotation} times
@param rotation
number of times to rotate queue"""
def rotate(self, rotation):
for i in range(rotation):
temp = self.stack[0]
self.stack = self.stack[1:]
self.put(temp)
self.length = self.length - 1
"""Reports item at the front of self
@return item at front of self.stack"""
def front(self):
front = self.get()
self.put(front)
self.rotate(self.length-1)
return front
"""Returns the length of this.stack"""
def size(self):
return self.length

View File

View File