c++迭代器遍历数组
时间: 2024-08-13 10:02:58 浏览: 50
在 C++ 中,迭代器是一种特殊的指针,用于遍历容器(如数组、向量、列表等)中的元素。它们使得我们可以按照一定的顺序访问容器中的数据,而不需要关心底层的具体存储机制。对于数组,虽然它不是标准库容器,但我们仍然可以使用迭代器来遍历。
以下是使用迭代器遍历整型数组的基本步骤:
1. 定义一个指向数组首元素的迭代器 `iterator_type array_start = &array;`,这里的 `&array` 是数组的起始地址。
2. 使用 `++iterator` 或 `iterator++` 来移动迭代器到下一个元素,直到达到数组结束,通常我们检查 `iterator != array_end` 这样的条件,其中 `array_end` 是数组最后一个元素的地址加一。
3. 使用迭代器访问元素,例如 `*iterator` 或 `*(iterator++)`。
示例代码如下:
```cpp
int array[] = {1, 2, 3, 4, 5};
std::size_t size = sizeof(array) / sizeof(array);
int* end = array + size;
// 迭代器遍历数组
for (int* iterator = array; iterator != end; ++iterator) {
std::cout << *iterator << " ";
}
```
相关问题
c++ 迭代器遍历map数组
在C++中,我们可以使用迭代器来遍历map数组。map的迭代器是一个指向pair对象的指针,pair的第一个元素是key,第二个元素是value。
以下是一个简单的例子:
```c++
#include <iostream>
#include <map>
using namespace std;
int main() {
map<string, int> m {{"one", 1}, {"two", 2}, {"three", 3}};
// 使用迭代器遍历map
for (auto it = m.begin(); it != m.end(); ++it) {
cout << it->first << ": " << it->second << endl;
}
return 0;
}
```
输出结果为:
```
one: 1
three: 3
two: 2
```
可以看到,我们使用迭代器遍历了整个map数组,并输出了每个key-value对的内容。需要注意的是,map是按照key的大小进行排序的,因此遍历的顺序可能与插入的顺序不同。
c++ 用迭代器遍历vector数组
可以通过以下代码使用迭代器遍历vector数组:
```c++
#include <iostream>
#include <vector>
int main()
{
std::vector<int> vec = {1, 2, 3, 4, 5};
// 使用迭代器遍历vector数组
for (std::vector<int>::iterator it = vec.begin(); it != vec.end(); ++it)
{
std::cout << *it << " ";
}
return 0;
}
```
输出结果为:
```
1 2 3 4 5
```
其中,`vec.begin()` 返回一个指向vector第一个元素的迭代器,`vec.end()` 返回一个指向vector最后一个元素的下一个位置的迭代器,注意这个迭代器并不指向最后一个元素本身。在遍历时,使用 `*it` 取出迭代器指向的值。
阅读全文