如何在 C++ 中將向量轉換為陣列
Jinku Hu
2023年10月12日
本文將介紹如何在 C++ 中把一個向量轉換為陣列。
使用 data()方法將雙向量轉換為陣列
由於 C++ 標準保證 vector
容器元素在記憶體中是連續儲存的,所以我們可以呼叫內建向量方法 data()
,並將返回的地址分配給新宣告的 double
指標,如下面的程式碼示例所示。
請注意,使用 d_arr
指標對元素的任何修改都會改變原始向量的資料元素,因為我們只是指向 arr
元素,而不是將它們複製到一個新的位置。
#include <iostream>
#include <iterator>
#include <vector>
using std::cin;
using std::copy;
using std::cout;
using std::endl;
using std::vector;
int main() {
vector<double> arr{-3.5, -21.1, -1.99, 0.129, 2.5, 3.111};
copy(arr.begin(), arr.end(), std::ostream_iterator<double>(cout, "; "));
cout << endl;
double *d_arr = arr.data();
for (size_t i = 0; i < arr.size(); ++i) {
cout << d_arr[i] << "; ";
}
cout << endl;
return EXIT_SUCCESS;
}
輸出:
-3.5; -21.1; -1.99; 0.129; 2.5; 3.111;
-3.5; -21.1; -1.99; 0.129; 2.5; 3.111;
使用&
操作符的地址將向量轉換為陣列
另外,我們也可以使用 &
運算子,它可以提取記憶體中物件的地址,並將其分配給新宣告的 double
指標。
在這個例子中,我們取的是 vector
中第一個元素的地址,但你可以提取一個指向任何其他元素的指標,並根據需要進行操作。
元素可以用 d_arr[index]
陣列符號來訪問,與前面的方法類似,對 d_arr
的任何修改都會影響 arr
資料。
#include <iostream>
#include <iterator>
#include <vector>
using std::cin;
using std::copy;
using std::cout;
using std::endl;
using std::vector;
int main() {
vector<double> arr{-3.5, -21.1, -1.99, 0.129, 2.5, 3.111};
copy(arr.begin(), arr.end(), std::ostream_iterator<double>(cout, "; "));
cout << endl;
double *d_arr = &arr[0];
for (size_t i = 0; i < arr.size(); ++i) {
cout << d_arr[i] << "; ";
}
cout << endl;
return EXIT_SUCCESS;
}
使用 copy()
函式將向量轉換為陣列
可以利用 copy()
方法將一個向量轉換為陣列,以便將資料元素複製到不同的記憶體位置。之後,我們可以修改它們,而不用擔心改變原來的向量資料。
注意,我們宣告的是一個固定 6 個元素的 d_arr
,它被分配為棧記憶體。在大多數情況下,不會預先知道陣列的大小,所以你需要使用動態的記憶體分配方法,如 new
或 malloc
。
#include <iostream>
#include <iterator>
#include <vector>
using std::cin;
using std::copy;
using std::cout;
using std::endl;
using std::vector;
int main() {
vector<double> arr{-3.5, -21.1, -1.99, 0.129, 2.5, 3.111};
copy(arr.begin(), arr.end(), std::ostream_iterator<double>(cout, "; "));
cout << endl;
double d_arr[6];
copy(arr.begin(), arr.end(), d_arr);
for (size_t i = 0; i < arr.size(); ++i) {
cout << d_arr[i] << "; ";
}
cout << endl;
return EXIT_SUCCESS;
}
輸出:
new_vec - | 97 | 98 | 99 | 100 | 101 |
作者: Jinku Hu