做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[...
vector<int> v(5); 3.声明一个长度为5,所有元素初始值为0的容器 vector<int> v(5,0); 4.用已有的数组初始化容器,区间:[a,a 6) int a[6]={5,6,2,0,9,4}; vector<int > v(a,a 6); 5.用现有容器初始化一个容器 vector<int> v1(5,0); ...
鉴于以上原因,在C语言中,如果想用变长的数组,还是老老实实用malloc分配吧,在C++中当然有更好的选择,就是vector,当然C++11中又推出了一个array,而且这两种都是真正的变长,也就是数组的长度随时都可以改变。 下面我还想说一下C和C++中const关键字的区别。
因此删除vector中任意位置上元素时,vs就认为该位置迭代器失效了注意:Linux下,g++编译器对迭代器失效的检测并不是非常严格,处理也没有vs下极端从上述三个例子中可以看到:SGI STL中,...,vector的容量为: " << v.capacity() << endl; // 经过上述reserve...
const)并且循环体包含对其他函数的调用,则编译器通常必须假设这些函数可能改变它,从而阻止长度计算的提升...
他的长度就更简单了,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...