281 Zigzag Iterator
v1 = [1, 2]
v2 = [3, 4, 5, 6][1,2,3]
[4,5,6,7]
[8,9]class ZigzagIterator {
public:
ZigzagIterator(vector<int>& v1, vector<int>& v2) {
iter1 = v1.begin();
iter2 = v2.begin();
end1 = v1.end();
end2 = v2.end();
}
int next() {
// need to define a priority
if (iter1 == end1) {
return *iter2++;
}
else if (iter2 == end2) {
return *iter1++;
}
else if (is_v1) {
is_v1 = !is_v1;
return *iter1++;
}
else if (!is_v1) {
is_v1 = !is_v1;
return *iter2++;
}
}
bool hasNext() {
return !(iter1 == end1 && iter2 == end2);
}
private:
vector<int>::iterator iter1, iter2;
vector<int>::iterator end1, end2;
bool is_v1 = true;
};
/**
* Your ZigzagIterator object will be instantiated and called as such:
* ZigzagIterator i(v1, v2);
* while (i.hasNext()) cout << i.next();
*/Last updated