map

第一个只出现一次的字符

http://www.nowcoder.com/questionTerminal/1c82e8cf713b4bbeb2a5b31cf5b0417c

1.map简介
map是STL(Stand )的一个关联容器,提供一对一的hash
·第一个可以称为关键字(key),每个关键字只在map中出现一次;
·第二个可以称为改关键字的值(value);
map内部实现自建一棵红黑树,这棵树具有对数据自动排序的功能。在map内部所有的数据都是有序的。
2.map的使用
库:
构造函数构造一个map:map<int,string> mapstdent;
插入元素的三种方法:
·mapstudent.insert(pair<int,string>(000,"student_zero"));//insert函数插入pair
·mapstudent.insert(map<int,string>::value_type(001,"student_one"));//insert函数插入value_type数据
·mapstudent[002]="student_two";
noteq区别:当map中有这个关键字时,insert操作是不能在插入数据的,但是用数组方式就不同了,它可以覆盖以前该关键字对应的值。
查找元素:iter = mapstudent.find("123");
如果没有iter与end函数的值相同(if(iter!= mapstudent.end())
删除元素:
·迭代器删除 mapstudent.erase(iter);
·关键字删除 int n= mapstudent.erase("123")//删除成功返回1,否则返回0
·mapstudent.erase(mapstudent.begin(),mapstudent.end());
等同于mapstudent.clear()

class Solution {
public:
    int FirstNotRepeatingChar(string str) {
        map<char,int> mp;
        for ( const char ch : str){
            ++mp[ch];
        }
        for(int i=0;i<str.length();i++)
        {
            if(mp[str[i]] == 1) return i;
        }
        return -1;
    }
};
//map的第一元素视为关键字key,在map中只能出现一次
//map的第二元素视为关键字的值value
全部评论

相关推荐

点赞 1 评论
分享
牛客网
牛客企业服务