如何理解“ vector <int> avector(arr,arr + sizeof(arr)/ sizeof(arr [0]))”?

时间:2019-08-13 07:41:41

标签: c++ arrays vector stl

在下面的代码中,

是什么意思
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;
}

谢谢!

杰夫

3 个答案:

答案 0 :(得分:5)

vector<int> avector (arr, arr + sizeof(arr) / sizeof(arr[0]) );

std::vector C样式数组中初始化avectorarr

参数是迭代器。这些迭代器定义了一系列元素:

  • 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复制到向量0n-1(包括端点)

答案 2 :(得分:1)

avector是通过复制arr的所有元素来构造的。

它使用以下向量constructor

template< class InputIt >
vector( InputIt first, InputIt last, 
        const Allocator& alloc = Allocator() );