C/C++ map

#include <iostream>
#include <map>
#include <sstream>
#include <string>
#include <vector>
#include <algorithm>
#include <functional> 
 
using namespace std;
 
struct FoundByValue 
{
    FoundByValue(string str):_s(str) {}
    bool operator() (const pair<int, string>& v) const
    {
        return v.second == _s;
    }
private:
   string _s;    
};
 
int main(int argc, char** argv) 
{
    char sz[] = "I am a map of int and string.";
    string token;
    stringstream ss (sz);    
    map<int, string> mis;
    map<int, string>::iterator itmap;    
    int i;
     
    i = 0;
    while (getline(ss, token, ' ')) 
    {    
        mis[i++] = token;
    }
     
    for (itmap = mis.begin(); itmap != mis.end(); ++itmap)
    {
        cout << (*itmap).first << " " << (*itmap).second << endl;
    }
     
    vector<string> vs;
    vs.push_back("int");
    vs.push_back("float");
     
    for (vector<string>::iterator it = vs.begin(); it != vs.end(); ++it)    
    {
        itmap = find_if(mis.begin(), mis.end(), FoundByValue(*it));
        if ( itmap != mis.end())
           cout << *it << " already exists." << endl;
        else
           cout << *it << " is not found." << endl;
    } 
     
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值