Skip to content

Latest commit

 

History

History
54 lines (47 loc) · 1.43 KB

284.md

File metadata and controls

54 lines (47 loc) · 1.43 KB

284. Peeking Iterator

Solution 1 (time O(1), space O(1))

# Below is the interface for Iterator, which is already defined for you.
#
# class Iterator(object):
#     def __init__(self, nums):
#         """
#         Initializes an iterator object to the beginning of a list.
#         :type nums: List[int]
#         """
#
#     def hasNext(self):
#         """
#         Returns true if the iteration has more elements.
#         :rtype: bool
#         """
#
#     def next(self):
#         """
#         Returns the next element in the iteration.
#         :rtype: int
#         """

class PeekingIterator:
    def __init__(self, iterator):
        self.iter = iterator
        if self.iter.hasNext():
            self.cur_value = self.iter.next()
        else:
            self.cur_value = None

    def peek(self):
        return self.cur_value

    def next(self):
        ans = self.cur_value
        if self.iter.hasNext():
            self.cur_value = self.iter.next()
        else:
            self.cur_value = None
        return ans

    def hasNext(self):
        return self.cur_value is not None

# Your PeekingIterator object will be instantiated and called as such:
# iter = PeekingIterator(Iterator(nums))
# while iter.hasNext():
#     val = iter.peek()   # Get the next element but not advance the iterator.
#     iter.next()         # Should return the same value as [val].