Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1501043
  • 博文数量: 218
  • 博客积分: 6394
  • 博客等级: 准将
  • 技术积分: 2563
  • 用 户 组: 普通用户
  • 注册时间: 2008-02-08 15:33
个人简介

持之以恒

文章分类

全部博文(218)

文章存档

2013年(8)

2012年(2)

2011年(21)

2010年(55)

2009年(116)

2008年(16)

分类: C/C++

2010-01-17 09:50:32

1.问题
使用stdext::hash_map在有的平台上编译通不过的问题
相应的解决方法是:

#pragma once
#include <hash_map>
#include <string>
#include <iostream>
struct MyStringComp
{
    //define hash function for strings
    enum
    {
        //parameters for hash table
        bucket_size = 4,
        min_buckets = 8
    };
    size_t operator()(const std::string & s1) const
    {
        //hash string s1 to size_t value
        const unsigned char * p = (const unsigned char *)s1.c_str();
        size_t hashval = 0;
        for (size_t n = s1.size();0 < n;--n)
            hashval += *p++; //or whatever
        return (hashval);
    }
    bool operator()(const std::string & s1, const std::string & s2) const
    {    
        if (s1.compare(s2) < 0)
        {
            return true;
        }
        else
        {
            return false;
        }
    }
};

int main(int arg,char * argv[])
{
    stdext::hash_map<std::string,int, MyStringComp> mapStringTable;
    mapStringTable.insert(std::pair<std::string,int>("13136",5));
    mapStringTable.insert(std::pair<std::string,int>("16633",10));
    mapStringTable.insert(std::pair<std::string,int>("16733",10));
    mapStringTable.insert(std::pair<std::string,int>("16833",10));
    mapStringTable.insert(std::pair<std::string,int>("16933",10));
    mapStringTable.insert(std::pair<std::string,int>("16033",10));
    stdext::hash_map<std::string,int, MyStringComp>::iterator It;
    It = mapStringTable.find("16833");
    if (It != mapStringTable.end())
    {
        std::cout<<It->first;
    }
    getchar();
    return 0;
}

2.输出
find成功!呵呵

阅读(4921) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~