?LeetCode刷題實戰(zhàn)251:展開二維向量
Implement an iterator to flatten a 2d vector.
示例
Input: 2d vector =
[
[1,2],
[3],
[4,5,6]
]
Output: [1,2,3,4,5,6]
解題
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;
};
LeetCode1-240題匯總,希望對你有點(diǎn)幫助!
LeetCode刷題實戰(zhàn)241:為運(yùn)算表達(dá)式設(shè)計優(yōu)先級
LeetCode刷題實戰(zhàn)242:有效的字母異位詞
LeetCode刷題實戰(zhàn)244:最短單詞距離 II
LeetCode刷題實戰(zhàn)245:最短單詞距離 III
LeetCode刷題實戰(zhàn)246:中心對稱數(shù)
LeetCode刷題實戰(zhàn)247:中心對稱數(shù)II
LeetCode刷題實戰(zhàn)248:中心對稱數(shù)III
LeetCode刷題實戰(zhàn)250:統(tǒng)計同值子樹
