你可以使用if(*it == n)
{num++;}使用num判断是vector的第几个元素。
一般没这么用的vetor的成员函数可以实现你想要的数据
begin() 返回指向map头部的迭代器
clear() 删除所有元素
count() 返回指定元素出现的次数
empty() 如果map为空则返回true
end() 返回指向map末尾的迭代器
equal_range() 返回特殊条目的迭代器对
erase() 删除一个元素
find() 查找一个元素
get_allocator() 返回map的配置器
insert() 插入元素
key_comp() 返回比较元素key的函数
lower_bound() 返回键值>=给定元素的第一个位置
max_size() 返回可以容纳的最大元素个数
rbegin() 返回一个指向map尾部的逆向迭代器
rend() 返回一个指向map头部的逆向迭代器
size() 返回map中元素的个数
swap() 交换两个map
upper_bound() 返回键值>给定元素的第一个位置
value_comp() 返回比较元素value的函数
http://blog.csdn.net/huang_xw/article/details/7626922
- #include <iostream>
- #include <vector>
- #include <iterator>
-
- int main()
- {
- int ar[10] = {11, 12, 13, 14, 15, 16, 17, 18, 19, 20};
- std::vector<int> v(ar, ar+10);
- std::vector<int> v1(5, 88);
-
-
- for (std::vector<int>::iterator it=v.begin(); it!=v.end(); ++it)
- std::cout << *it << " ";
- std::cout << std::endl;
-
-
- v.push_back(21);
- for (std::vector<int>::iterator it=v.begin(); it!=v.end(); ++it)
- std::cout << *it << " ";
- std::cout << std::endl;
-
-
- v.insert(v.begin()+1, 99);
- for (std::vector<int>::iterator it=v.begin(); it!=v.end(); ++it)
- std::cout << *it << " ";
- std::cout << std::endl;
-
- v1.insert(v1.begin()+1, v.begin()+2, v.begin()+5);
- for (std::vector<int>::iterator it=v1.begin(); it!=v1.end(); ++it)
- std::cout << *it << " ";
- std::cout << std::endl;
-
-
- v1.assign(6, 77);
- for (std::vector<int>::iterator it=v1.begin(); it!=v1.end(); ++it)
- std::cout << *it << " ";
- std::cout << std::endl;
-
-
- std::cout << v.front() << " ";
- std::cout << v.back() << " ";
- std::cout << v.at(3) << " ";
- std::cout << v[3] << " ";
- std::cout << std::endl;
-
-
- v.pop_back();
- for (std::vector<int>::iterator it=v.begin(); it!=v.end(); ++it)
- std::cout << *it << " ";
- std::cout << std::endl;
-
- v.erase(v.begin()+2, v.begin()+4);
- for (std::vector<int>::iterator it=v.begin(); it!=v.end(); ++it)
- std::cout << *it << " ";
- std::cout << std::endl;
-
- return 0;
- }