Leetcode: Zigzag Iterator

本文介绍了一种名为交错迭代器的设计方案,该方案可以接收两个一维向量,并按交替顺序返回它们的元素。同时探讨了如何将此设计扩展到处理多个向量的情况。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Question

Given two 1d vectors, implement an iterator to return their elements alternately.

For example, given two 1d vectors:

v1 = [1, 2]
v2 = [3, 4, 5, 6]
By calling next repeatedly until hasNext returns false, the order of elements returned by next should be: [1, 3, 2, 4, 5, 6].

Follow up: What if you are given k 1d vectors? How well can your code be extended to such cases?
Hide Tags Design
Hide Similar Problems (M) Binary Search Tree Iterator (M) Flatten 2D Vector


My Solution

class ZigzagIterator(object):

    def __init__(self, v1, v2):
        """
        Initialize your data structure here.
        :type v1: List[int]
        :type v2: List[int]
        """

        self.v1, self.v2 = v1, v2
        self.ind1, self.ind2 = 0,0

        self.flag = 1


    def next(self):
        """
        :rtype: int
        """

        if self.hasNext():
            if self.ind1==len(self.v1) and self.ind2!=len(self.v2):
                res = self.v2[self.ind2]
                self.ind2 += 1
            elif self.ind2==len(self.v2) and self.ind1!=len(self.v1):
                res = self.v1[self.ind1]
                self.ind1 += 1
            else:
                if self.flag==1:
                    res = self.v1[self.ind1]
                    self.ind1 += 1
                    self.flag = 2
                else:
                    res = self.v2[self.ind2]
                    self.ind2 += 1
                    self.flag = 1
            return res                    

    def hasNext(self):
        """
        :rtype: bool
        """

        if self.ind1==len(self.v1) and self.ind2==len(self.v2):
            return False
        else:
            return True



# Your ZigzagIterator object will be instantiated and called as such:
# i, v = ZigzagIterator(v1, v2), []
# while i.hasNext(): v.append(i.next())
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值