做leetcode默认是写函数,当出现关于数组的题目时,一般来说C++传入类型是vector,C传入类型是int型数组或char型数组,同时也需要知道数组的长度,在此一并总结。 1.非字符串数组: sizeof(array) /sizeof(datatype) 注意如果用指针作为实参传入函数,sizeof(array)的值将出错,变为所指地址的值的长度 在C中可以用宏...
for (vector<int>::size_type ix = 0; ix != v.size(); ix ++){ printf("%d\t", v[ix]); } printf("\n"); printf("second: "); for (vector<int>::size_type ix1 = 0; ix1 != v1.size(); ix1 ++){ printf("%d\t", v1[ix1]); } printf("\n"); printf("third: ")...
//初始化一个一维长度为3的vectorvector<vector<int>> vec(3);//为每个一维vector初始化不同长度vec[0] = vector<int>(5); vec[1] = vector<int>(10); vec[2] = vector<int>(2);//打印vecfor(inti =0; i < vec.size(); ++i) {for(intj =0; j < vec[i].size(); ++j) { cout<<...
vector 是个容器 是复合类型 vector<char> 不会自动添加~ 是char 类型的容器 每个元素是一个个char字符 vecotr<string> 每个元素则会有\0 因为每个元素是string 类型的字符串 char str1[]="abcdefig";string str="abcdefig";const char str1*=str.c_str();是c风格的 字符串 char str1[...
(inti=1;i<arr.size();i++)arr[i][i]=1;}intmain(){intn=6;vector<vector<int>>arr;//编译无误,因为arr.size() == 0;arr[i][i]没有执行//编译有误,元素vector<int> 没有初始化,使用m[i][i]出错vector<vector<int>>arr(n);vector<vector<int>>arr(n,vector<int>(n));//编译无误...
鉴于以上原因,在C语言中,如果想用变长的数组,还是老老实实用malloc分配吧,在C++中当然有更好的选择,就是vector,当然C++11中又推出了一个array,而且这两种都是真正的变长,也就是数组的长度随时都可以改变。 下面我还想说一下C和C++中const关键字的区别。
因此删除vector中任意位置上元素时,vs就认为该位置迭代器失效了注意:Linux下,g++编译器对迭代器失效的检测并不是非常严格,处理也没有vs下极端从上述三个例子中可以看到:SGI STL中,...,vector的容量为: " << v.capacity() << endl; // 经过上述reserve...
C++中size()函数除了跟length()函数一样可以获取字符串长度之外,还可以获取vector类型的长度。size()主要是进行元素个数的计算,传入的参数一定要是一个数组。不能是单个变量或者是指针。 string str = "ADAS"; vector < int> num(10,5) int lenstr = str.size(); int lenvec = num.size(); //le...
vector<vector<vector<int>>> cube(5, vector<vector<int>>(3, vector<int>(2, 0))); 画的很简陋,随便欣赏一下。 补充内容: 1.声明一个简单int容器 vector<int> v; 2.声明一个长度为5的容器 vector<int> v(5); 3.声明一个长度为5,所有元素初始值为0的容器 ...
他的长度就更简单了,n = sizeof(a)/sizeof(int)假设数组存的是int型,那么 先申请10个元素;int* a = (int*)malloc(sizeof(int)*10);如果又来了个元素,那么就可以 a=(int *)realloc(a,11*sizeof(int));求元素个数int i,n=1;for(i = 0;(a+i)!=NULL;i++){ ;} n=i+1...