vector<float> X(x, x + sizeof(x) / sizeof(float)); vector<float> Y(y, y + sizeof(y) / sizeof(float)); 为什么要x + sizeof(x) / sizeof(float),y + sizeof(y) / sizeof(float)
时间: 2023-10-21 19:05:28 浏览: 75
vector的使用以及函数示例
在这段代码中,`x`和`y`是普数组,而`X`和`Y`是L vector容器。为了将普通数组换为vector容器,需要使用vector构造函数。
`sizeof(x) / sizeof)`用于计算数组的元素个数对于一个数组,`sizeof(x)`表示整个数组的字节大小,`sizeof(float)`表示单个元素的字节大小。通过相除,可以得到数组x中元素的个数。
`x + sizeof(x) / sizeof(float)`表示偏移指针,将指针从数组x的首地址向后移动了`sizeof(x) / sizeof(float)`个元素的位置。这样得到的指针就指向了数组x中的最后一个元素的下一个位置。同样的,`y + sizeof(y) / sizeof(float)`也是将指针偏移了相应的位置。
通过这样的操作,构造函数可以通过指针范围来初始化vector容器,从而将普通数组复制到vector中。这样可以方便地在后续的代码中使用vector容器进行操作和计算。
阅读全文