[C++]vector嵌套实现2D数组
2008-04-03 00:25
387 查看
从今天晚上开始,开始程序员的旅程;
从今天晚上开始,开始写代码;
从C++开始,从数据结构开始,从一个一个算法的实现开始,踏上征程,积跬步,至千里……
第一个问题是2维数组的实现。我们可以自定义一个Matrix<Type>类,来实现矩阵及其运算,这在很多帖子中都有谈到[1][2]。但是一般实现的都是每行每列的元素个数都是一样的“规矩”的阵列,而用vector嵌套可以实现每行元素个数不同的“矩阵”(已经不是传统意义上的矩阵了哦)。代码如下所示:
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/None.gif)
vector< vector<int> > vec2D;
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/None.gif)
vector<int> vec1(10,1);
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/None.gif)
vector<int> vec2(15,-1);
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/None.gif)
vec2D.push_back(vec1);
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/None.gif)
vec2D.push_back(vec2);
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/None.gif)
这种vector嵌套实现的2D数组在运算上不会有什么吸引人之处,但是可以用来灵活地存储和访问非规整的数据。
值得注意的是,在声明 vector< vector<int> >时,要用空格将最后两个> > 隔开,以免和插入流算子>>发生混淆。
【参考资料】
[1]http://www.zaoxue.com/article/tech-57909.htm, matrix(c++实现,初版)
[2]http://sourceforge.net/projects/ematrix/
从今天晚上开始,开始写代码;
从C++开始,从数据结构开始,从一个一个算法的实现开始,踏上征程,积跬步,至千里……
第一个问题是2维数组的实现。我们可以自定义一个Matrix<Type>类,来实现矩阵及其运算,这在很多帖子中都有谈到[1][2]。但是一般实现的都是每行每列的元素个数都是一样的“规矩”的阵列,而用vector嵌套可以实现每行元素个数不同的“矩阵”(已经不是传统意义上的矩阵了哦)。代码如下所示:
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/None.gif)
vector< vector<int> > vec2D;
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/None.gif)
vector<int> vec1(10,1);
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/None.gif)
vector<int> vec2(15,-1);
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/None.gif)
vec2D.push_back(vec1);
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/None.gif)
vec2D.push_back(vec2);
![](http://images.csdn.net/syntaxhighlighting/OutliningIndicators/None.gif)
这种vector嵌套实现的2D数组在运算上不会有什么吸引人之处,但是可以用来灵活地存储和访问非规整的数据。
值得注意的是,在声明 vector< vector<int> >时,要用空格将最后两个> > 隔开,以免和插入流算子>>发生混淆。
【参考资料】
[1]http://www.zaoxue.com/article/tech-57909.htm, matrix(c++实现,初版)
[2]http://sourceforge.net/projects/ematrix/
相关文章推荐
- C++实现仿vector的动态数组
- C++ 以传入vector的方式实现返回一个数组
- C++学习总结——顺序存储,链式存储,索引存储,哈希存储的优缺点,以及vector数组,list链表,十字链表,索引结构,hash表的实现
- C++ vector 数组实现
- c/c++实现的一个动态分配内存的结构体数组(类似vector)
- vector 容器内部的实现(数组)具体实现参考boost库在另一篇文章
- 队列(queue)的链表(list)实现及循环数组(circular array)实现 C++实现
- c/c++ vector 的简单实现
- C/C++ 第八周串和数组 (一)稀疏矩阵的三元组表示的实现及应用 项目4—(1)
- LinuxC/C++编程基础(4) 基于泛型实现vector
- C++数组类型(非vector)
- 最大子数组问题-c++代码实现及运行实例结果
- 最大子数组问题-c++代码实现及运行实例结果
- C++实现数组大小运算符dimensionof()
- C++ : 用proxy Class实现简单的二维数组。
- 用C++容器vector实现通讯录功能
- C++用数组实现栈和循环队列
- C++晋升之std中vector的实现原理(标准模板动态库中矢量的实现原理)
- [C++] vector数组越届及关于引用的
- c++ 如何实现vector内容的复制