251展开二维向量

tech2022-10-20  112

题目描述: 请设计并实现一个能够展开二维向量的迭代器。该迭代器需要支持 next 和 hasNext 两种操作。、

示例: Vector2D iterator = new Vector2D([[1,2],[3],[4]]);

iterator.next(); // 返回 1 iterator.next(); // 返回 2 iterator.next(); // 返回 3 iterator.hasNext(); // 返回 true iterator.hasNext(); // 返回 true iterator.next(); // 返回 4 iterator.hasNext(); // 返回 false

注意: 请记得 重置 在 Vector2D 中声明的类变量(静态变量),因为类变量会 在多个测试用例中保持不变,影响判题准确。请 查阅 这里。 你可以假定 next() 的调用总是合法的,即当 next() 被调用时,二维向量总是存在至少一个后续元素。

方法1: 主要思路: (1)将原数组展开为一维的数组,然后使用一个变量来标识当前已经弹出的元素的个数;

class Vector2D { public: vector<int> nums;//存储元素 int size;//“弹出”的元素的个数 Vector2D(vector<vector<int>>& v) { for(int i=0;i<v.size();++i){ for(int j=0;j<v[i].size();++j){ nums.push_back(v[i][j]); } } size=0;//从0开始 } int next() { ++size; return nums[size-1];//返回值 } bool hasNext() { return nums.size()>size;//有没有“弹”完 } }; /** * Your Vector2D object will be instantiated and called as such: * Vector2D* obj = new Vector2D(v); * int param_1 = obj->next(); * bool param_2 = obj->hasNext(); */
最新回复(0)