在下面的代码中,
是什么意思vector<int> avector (arr, arr + sizeof(arr) / sizeof(arr[0]) );
在main()
中?
vector<int> bubbleSort(vector<int> avector) { //the vector for bubble sort
for (int passnum = avector.size()-1; passnum > 0; passnum -= 1) {
for (int i = 0; i < passnum; i++) {
if (avector[i] > avector[i+1]) {
int temp = avector[i];
avector[i] = avector[i+1];
avector[i+1] = temp;
}
}
}
return avector;
}
int main() {
// Vector initialized using a static array
static const int arr[] = {54,26,93,17,77,31,44,55,20};
vector<int> avector (arr, arr + sizeof(arr) / sizeof(arr[0]) );
vector<int> bvector = bubbleSort(avector);
for (unsigned int i = 0; i < bvector.size(); i++) {
cout<<bvector[i]<< " ";
}
return 0;
}
谢谢!
杰夫
答案 0 :(得分:5)
vector<int> avector (arr, arr + sizeof(arr) / sizeof(arr[0]) );
从std::vector
C样式数组中初始化avector
,arr
。
参数是迭代器。这些迭代器定义了一系列元素:
arr
:迭代器到要复制范围的第一个元素。arr + sizeof(arr) / sizeof(arr[0])
:迭代器指向要复制范围的过去-结束元素。 C ++ 11的方法是将函数模板std::cbegin()
和std::cend()
用于C型数组:
vector<int> avector(std::cbegin(arr), std::cend(arr));
此方法利用模板参数推导来推断C样式数组的大小。这种方式不太容易出错,因为它需要更少的输入。
答案 1 :(得分:4)
n = sizeof(arr) / sizeof(arr[0])
是数组存储的元素数。
avector(arr, arr + sizeof(arr) / sizeof(arr[0])
表示将数组arr
的元素从索引avector
复制到向量0
到n-1
(包括端点)
答案 2 :(得分:1)
avector
是通过复制arr
的所有元素来构造的。
它使用以下向量constructor:
template< class InputIt > vector( InputIt first, InputIt last, const Allocator& alloc = Allocator() );