LeetCode题解(0284):顶端迭代器(Python)

题目:原题链接(中等)

标签:设计

解法时间复杂度空间复杂度执行用时
Ans 1 (Python) O ( 1 ) O(1) O(1) O ( N ) O(N) O(N)44ms (44.22%)
Ans 2 (Python)
Ans 3 (Python)

解法一:

class PeekingIterator:
    def __init__(self, iterator):
        self.iterator = iterator
        self.top = None

    def peek(self):
        if not self.top:
            self.top = self.iterator.next()
        return self.top

    def next(self):
        if not self.top:
            return self.iterator.next()
        else:
            ans, self.top = self.top, None
            return ans

    def hasNext(self):
        if self.top:
            return True
        else:
            return self.iterator.hasNext()
已标记关键词 清除标记
©️2020 CSDN 皮肤主题: 游动-白 设计师:白松林 返回首页