今天和大家聊的问题叫做 展开二维向量,我们先来看题面:https://leetcode-cn.com/problems/flatten-2d-vector/
Implement an iterator to flatten a 2d vector.
请设计并实现一个能够展开二维向量的迭代器。该迭代器需要支持 next 和 hasNext 两种操作。
示例
Input: 2d vector = [ [1,2], [3], [4,5,6] ] Output: [1,2,3,4,5,6]
解题
需要维护两个动态迭代器row_it和col_it,分别表示当前位置的行和列。但是由于我们不存储vec2d本身,所以我们还需要另外一个静态迭代器row_end,表示整个二维数组的末尾。这里需要特别注意的是在判断hasNext的时候,要处理那种跳过空行的情况,请见下面的代码实现。
class Vector2D { public: Vector2D(vector<vector<int>>& vec2d) { if (vec2d.size() == 0) { return; } row_it = vec2d.begin(), row_end = vec2d.end(); col_it = (*row_it).begin(); } int next() { return *col_it++; } bool hasNext() { while (row_it != row_end && col_it == (*row_it).end()) { ++row_it; col_it = (*row_it).begin(); } return row_it != row_end; } private: vector<vector<int>>::iterator row_it, row_end; vector<int>::iterator col_it; };
好了,今天的文章就到这里,如果觉得有所收获,请顺手点个在看或者转发吧,你们的支持是我最大的动力 。