vector<vector<int>>
来源:互联网 发布:王侯将相宁有种乎电影 编辑:程序博客网 时间:2024/06/05 16:27
用vector取代C-style的数组
提起数组,大家想必都很熟悉,你可以用索引和指针来操作数组,给程序设计带来了很大的灵活性。但是你知道它有许多天生的缺陷吗?首先,数组的越界可能会引起程序的崩溃(如果崩溃了,还算你走运^_^)。其次是动态性不好,包括动态改变大小,动态申请。诸如此类的事,一定会让你伤透脑筋。有什么办法可以解决这些问题吗?
你不用担心,下面我来给大家介绍一种方法:用vector取代C-style的数组。
关于vector我不想多说,我假设大家都了解temlplate 和 STL。各位在任何一本C++的书上都可以找的到这些内容的(如果没有,那赶快把它扔掉)。那为什么是vector呢?我们知道vector提供了operator[]函数,可以像数组一样的操作,而且还有边界检查,动态改变大小。(从这点上deque也是可以的)。vector本来就是可以用来代替一维数组的,这里只介绍用它来代替二维的数组。二维以上的可以依此类推。
我们知道,C++的template参数是可以嵌套定义的,你可以这样定义一个模板的Instance
vector<vector<int> > array2(3);//注意>和>之间的空格。
这就是我们的关键,array2可以保存3个向量,向量的长度是可以改变的。array2[i]返回的是第i个向量。同理,array2[i][j]返回的是第i个向量中的第j个元素。
到这里,你可能会得意的说:"我明白了,很简单吗!"。别急,还有一些细节问题:如下
vector<vector<int> > array2(3);
array2[1][2]=9;
我保证你的程序会segement failed,原因就是你没有指定向量的大小。用push_back函数可以解决问题:array2[1].push_back(9);但是好象不太爽。就不能用operator[]吗?答案是肯定的。不过要多加几个步骤,如下:
for(int i=0;i<3;i++)
array2[i].resize(3);
这样,你就定义了一个3X3的数组了(另一个3在 申明时定义的)。而且你可以随时改变它的大小。
其他的,你还可以用C++的异常机制来捕获如下标越界等非法行为。进行必要的处理。使你的程序更加的健壮。具体的方法我就不深入介绍了。留给各位自己钻研。下面提供一个范例,供参考。
<span style="font-size:18px;"><span style="font-size:18px;"> //用vector来代替数组 // 潘李亮2002-1-13 //在GNU c++ Mandrake Linux7.0下通过, //在VC下会有变量定义问题,大家自己解决 #include <iostream> #include <vector> using namespace std; void main() { vector< vector<int> > array(3); for(int i=0;i<3;i++) array[i].resize(3);//设置数组的大小3X3 //现在你可以和使用数组一样使用这个vector for(int i=0;i<3;i++) for(int j=0;j<3;j++) array[i][j]=(i*j); //输出 for(int i=0;i<3;i++) { for(int j=0;j<3;j++) cout<<array[i][j]<<" "; cout<<endl; } array.resize(5); arry[3].resize(3); arry[4].resize(3); //现在是5X3的数组了 for(int i=0;i<5;i++) for(int j=0;j<3;j++) array[i][j]=(i*j); for(int i=0;i<5;i++) { for(int j=0;j<3;j++) cout<<array[i][j]<<" "; cout<<endl; } }</span></span>
信息来源:http://blog.csdn.net/wangyin159/article/details/46878091
下面是我自己照葫芦画瓢写出来的一段代码:
<span style="font-size:18px;"> //编写一个容器,进行数据的存储,分别对应正确的标签,检测正确的个数,实际需要检测的数量vector<vector<int>> mmm6(6);//mmm6[i]返回的是第i个向量。同理,mmm6[i][j]返回的是第i个向量中第j个元素for (int i = 0; i < 6; i++){mmm6[i].resize(2);}//指定向量大小,定义了一个6*2的数组for (int i = 0; i < 6; i++){mmm6[i][0]=0;mmm6[i][1]=0;}//全部初始化为0</span>
0 0
- vector<vector<int>>
- vector<vector<int>> 用法
- vector<vector<int>>
- vector<vector<int>>
- vector<vector<int> >初始化
- 二维向量:vector<vector<int>>
- vector<vector<int>>的输入
- C++中 vector<vector<int>>
- vector<vector<int> >array 理解
- vector<string>转为vector<int>
- vector<vector<int> >的输入输出
- vector<int>与vector<int>::iterator
- vector<int>G[] 和 vector<vector<int> G 的区别
- vector<int *> a
- vector<int>::size_type 解释
- vector<int>::iterator it
- 1063 vector<set<int > >
- vector<int> 转换为 int*
- C#之WinForm基础 不改变原有的,向textbox中追加新的内容
- 我学Hibernate - 05 SessionFactory
- google搜索语法,黑客必学
- 棋盘问题
- codeforce contest 713 #371 Div1 C
- vector<vector<int>>
- 发送邮件
- node学习-assert测试
- Minimum Depth of Binary Tree(求二叉树的最小深度)
- MyEclipse-blue2014怎样破解?
- NSOperation与performSelectorOnMainThread
- 使用Git将项目push至github
- 总结-UIWebView的使用-加载网页、html文件、本地文件等
- mac安装mysql数据库后忘记密码