Map集合的遍历常用的成员方法

Map集合

Map集合中的实现类的数据结构只针对键有效。
1.public interface Map(K, V);//将键映射到值的对象。一个映射不能包含重复的键,每个键最多只能映射到一个值。
举例:学生的学号和姓名
Map<String, String> map = new HashMap<String, String>();//创建集合对象
map.put(“it001”, “林青霞”);//添加元素, put(K key, V value);
键不能重复。如果键重复,就会用新值替换这个键的老值。
System.out.println(map);//输出结果

2.常用的成员方法
V put(K key, V value);//添加元素,如果键是第一次存储,就直接存储元素,返回null。如果键不是第一次存储,就用值把以前的值替换,返回以前的值。
V remove(Object key);//根据键删除键值对的元素,返回要删除的值
void clear();//移除所有的键值对元素
boolean containsKey(Object key);//判断集合是否包含指定的键
boolean containsValue(Object value);//判断集合是否包含指定的值
boolean isEmpty();//判断集合是否为空
int size();//返回键值对的对数

3.Map的获取方法
V get(Object key);//根据键获取值。没有键就返回null。
Set keySet();//获取所有键的集合
Collection values();//获取所有值的集合
代码:
map.get(“张无忌”);//返回赵敏
Set set = map.keySet();//获取所有键的集合
for(String key : set){
System.out.println(key);//郭靖,杨过,张无忌
}
Collection values = map.values();//获取所有值的集合
for(String value : values){
System.out.println(value);//黄蓉,小龙女,赵敏

4.Map集合的遍历
因为Map集合是双列的,所以不能用迭代器,不能用增强for。
遍历方式一:键找值
思路:把Map看成是一个夫妻对的集合,A.把所有的丈夫给集中起来;B.遍历丈夫的集合,获取到每一个丈夫;C.根据丈夫去找对应的妻子。
即:A.获取所有键的集合(keySet()); B.遍历键的集合,获取到每一个键(增强for);C.根据键去找值(V get(Object key))。
代码:
//创建集合对象
Map<String, String> map = new HashMap<String, String>();
//添加元素
map.put(“郭靖”, “黄蓉”);
map.put(“杨过”, “小龙女”);
map.put(“张无忌”, “赵敏”);
//获取所有键的集合
Set set = map.keySet();
//遍历键的集合,获取到每一个键
for(String key : set){
//根据键去找值
String value = map.get(key);
System.out.println(key + “–” + value);
}

遍历方式二:键值对对象找键和值
思路:A.获取所有结婚证的集合;B.遍历结婚证的集合,得到每一个结婚证;C.根据结婚证获取丈夫和妻子
即:A.获取所有键值对对象的集合(Set<Map.Entry<K, V>> entrySet(););B.遍历键值对对象的集合,得到每一个键值对对象(增强for);C.根据键值对对象获取键和值(getKey(), getValue())。
代码:
//创建集合对象
Map<String, String> map = new HashMap<String, String>();
//添加元素
map.put(“郭靖”, “黄蓉”);
map.put(“杨过”, “小龙女”);
map.put(“张无忌”, “赵敏”);
//获取所有键值对对象的集合Set<Map.Entry<K, V>> entrySet();
Set<Map.Entry<String, String>> set = map.entrySet();
//遍历键值对对象的集合,得到每一个键值对对象
for(Map.Entry<String, String> me : set){
//根据键值对对象,获取键和值
String key = me.getKey();
String value = me.getValue();
System.out.println(key + “–” + value);
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Map是一种非常有用的集合类型,在C++中可以使用STL中的map结构来存储一组键值对。在程序中有时需要遍历map的key集合,这可以通过迭代器来实现。 在STL中,map类型实现了迭代器,可以通过begin()函数得到指向第一个元素的迭代器,通过end()函数得到指向最后一个元素的下一个位置的迭代器。因此,可以使用迭代器来遍历map中的key值集合。 下面是一个遍历map中key集合的示例程序: ``` #include <iostream> #include <map> int main() { std::map<int, std::string> myMap; myMap[1] = "one"; myMap[2] = "two"; myMap[3] = "three"; std::map<int, std::string>::iterator it; for(it = myMap.begin(); it != myMap.end(); it++) { int key = it->first; std::cout << "key = " << key << std::endl; } return 0; } ``` 在这个示例程序中,首先定义了一个包含三个键值对的map。然后通过定义一个迭代器变量it,使用迭代器来遍历整个map。在每一次迭代的过程中,通过迭代器的first成员获取当前元素的key值,将其输出到屏幕上。 因此,可以通过迭代器来实现遍历map中的key集合,这种方法非常灵活,可以应用于不同类型的map。 ### 回答2: map是C++标准库中的一个关联容器,用于存储键值对。其内部实现是基于红黑树,因此在插入和查找操作上效率比较高。 如果要遍历map的key,可以使用迭代器来实现。具体步骤如下: 1. 定义一个迭代器变量,可以使用auto关键字自动推导类型。 ``` auto iter = map_name.begin(); ``` 2. 使用while循环遍历整个map,直到迭代器指向map的末尾位置。 ``` while(iter != map_name.end()) { // 后续操作 ++iter; } ``` 3. 在循环内部获取当前迭代器所指位置的key,可以使用迭代器的->符号获取key。 ``` auto current_key = iter->first; ``` 完整代码如下: ```c++ #include <iostream> #include <map> int main() { std::map<int, std::string> str_map = {{1, "Hello"}, {2, "Goodbye"}, {3, "World"}}; auto iter = str_map.begin(); while(iter != str_map.end()) { auto current_key = iter->first; std::cout << current_key << " "; ++iter; } return 0; } ``` 输出结果为:1 2 3 ### 回答3: 在C++中,可以通过迭代器遍历一个map的所有key。具体操作如下: ```c++ #include <iostream> #include <map> using namespace std; int main() { map<string, int> my_map; my_map["apple"] = 3; my_map["banana"] = 5; my_map["cherry"] = 2; // 遍历map的key map<string, int>::iterator it; for (it = my_map.begin(); it != my_map.end(); it++) { cout << it->first << endl; } return 0; } ``` 在上面的代码中,我们定义了一个map对象my\_map,并给它添加了三个key-value对。接着,我们使用迭代器it遍历了整个map,并在循环内部输出了每个key。 需要注意的是,由于map是按键值有序存储的,因此迭代器it指向的键值会按从小到大的顺序依次遍历。如果希望逆序遍历key,可以使用反向迭代器rbegin和rend: ```c++ for (map<string, int>::reverse_iterator rit = my_map.rbegin(); rit != my_map.rend(); rit++) { cout << rit->first << endl; } ``` 在本例中,我们使用了反向迭代器rit,并调用了rbegin和rend方法。这样,我们会逆序遍历整个map,并输出每个key。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值