VS2012关于hash_map的使用简略
VS关于hash_map使用的一些经常使用构造方法汇总,包含基本类型和结构体,相信够一般模仿使用:
# include<hash_map>
#include<iostream>
#include<string>
struct order
{
char orderNO[20];
char name[10];
int NO;
char type;
};
typedef order Order;
struct cmp{
enum
{
bucket_size=100,
};
size_t operator()(Order order1)
{
return sizeof(order1.orderNO)+sizeof(order1.name)+sizeof(order1.NO)+sizeof(order1.type);
} bool operator()(Order order1,Order order2)
{
if(strcmp(order1.orderNO,order2.orderNO)>0)
return true;
else if(strcmp(order1.orderNO,order2.orderNO)<0)
return false;
else
{
if(strcmp(order1.name,order2.name)>0)
return true;
else if(strcmp(order1.name,order2.name)<0)
return false;
else{
if(order1.NO>order2.NO)return true;
else if(order1.NO<order2.NO)return false;
else{
if(order1.type>order2.type)return true;
else return false;
}
}
}
} }; struct CharLess : public std::binary_function<const char*,const char*, bool>
{
public:
result_type operator()(const first_argument_type& _Left, const second_argument_type& _Right) const
{
return(stricmp(_Left, _Right) < 0 ? true : false)<span style="font-family: Arial, Helvetica, sans-serif;">;</span>
}
}; struct CharLess1 : public std::binary_function<char*, char*, bool>
{
public:
result_type operator()(const first_argument_type& _Left, const second_argument_type& _Right) const
{
return(stricmp(_Left, _Right) < 0 ? true : false);
}
}; void testHashMap()
{
stdext::hash_map<int,int> mhasp_map1;
for(int i=0;i<9;i++)
mhasp_map1.insert(stdext::pair<int,int>(i,i+10));
stdext::hash_map<int,int>::iterator mit1=mhasp_map1.begin();
while(mit1!=mhasp_map1.end())
{
std::cout<<mit1->first<<" "<<mit1->second<<std::endl;
mit1++;
} stdext::hash_map<const char*,std::string,std::hash_compare<const char *,CharLess> > testhash;
testhash["东方不败"]="葵花宝典,技压群雄";
testhash["西门吹雪"]="寒剑三尺,削铁如泥";
testhash["上官玉儿"]="花容月貌,一笑倾城";
stdext::hash_map<const char *,std::string,std::hash_compare<const char *,CharLess> >::iterator testhashit=testhash.begin();
while(testhashit!=testhash.end())
{
std::cout<<testhashit->first<<" "<<testhashit->second.c_str()<<std::endl;
testhashit++;
}
char a[20];
scanf("%s",a);
std::cout<<testhash.find(a)->first<<std::endl; stdext::hash_map<char *,std::string,std::hash_compare<char *,CharLess1> > testhash1;
testhash1["东方不败"]="葵花宝典。技压群雄";
testhash1["西门吹雪"]="寒剑三尺,削铁如泥";
testhash1["上官玉儿"]="花容月貌,一笑倾城";
stdext::hash_map<char *,std::string,std::hash_compare<char *,CharLess1> >::iterator testhashit1=testhash1.begin();
while(testhashit1!=testhash1.end())
{
std::cout<<testhashit1->first<<" "<<testhashit1->second<<std::endl;
testhashit1++;
} //char a[20]; scanf("%s",a);
std::cout<<testhash.find(a)->first<<std::endl;
//std::cout<<testhash1.find("东方不败")->first<<std::endl;
stdext::hash_map<std::string,std::string> testhash2;
testhash2["东方不败"]="葵花宝典,技压群雄";
testhash2["西门吹雪"]="寒剑三尺,削铁如泥";
testhash2["上官玉儿"]="花容月貌。一笑倾城";
stdext::hash_map<std::string,std::string>::iterator testhashit2=testhash2.begin();
while(testhashit2!=testhash2.end())
{
std::cout<<testhashit2->first<<" "<<testhashit2->second<<std::endl;
testhashit2++;
} scanf("%s",a);
std::string str(a);
std::cout<<testhash2.find(str)->first<<std::endl; Order order1={"SR405","小麦",100,10};
Order order2={"SR406","小麦",100,10};
Order order3={"SR406","小米",100,10};
Order order4={"SR406","小米",101,10};
Order order5={"SR406","小米",101,11};
stdext::hash_map<Order,std::string,cmp> teststruct;
teststruct.insert(std::pair<Order,std::string>(order1,"sr112"));
teststruct.insert(std::pair<Order,std::string>(order2,"sr113"));
teststruct.insert(std::pair<Order,std::string>(order3,"sr114"));
teststruct.insert(std::pair<Order,std::string>(order4,"sr115"));
teststruct.insert(std::pair<Order,std::string>(order5,"sr116"));
stdext::hash_map<Order,std::string,cmp>::iterator it;
it=teststruct.find(order1);
std::cout<<it->second<<std::endl;
g<span style="font-family: Arial, Helvetica, sans-serif;">etchar();</span>
}
int main()
{
testHashMap();
getchar();
}
假设有不明白的地方。请參考博客:http://blog.csdn.net/sdhongjun/article/details/4517325,这位大神写的比較具体,细致看看。
VS2012关于hash_map的使用简略的更多相关文章
- VS2012+EF6+Mysql配置心路历程
为了学习ORM,选择了EntityFramework,经历了三天两夜的煎熬,N多次错误,在群里高手的帮助下,终于成功,现在将我的心路历程记录下来,一是让自己有个记录,另外就是让其它人少走些弯路. 我的 ...
- VS2010 VS2012 VS2013 VS2015启动调试时老是提示正在下载公共符号
VS2010 VS2012 VS2013 VS2015启动调试时老是提示正在下载公共符号,下载一些.dll文件,点取消后也能继续调试,但特别慢.解决方法:工具-选项,或者调试-选项和设置,将调试下的& ...
- VS2012程序打包部署详解
VS2012没有自带打包工具,所以要先下载并安装一个打包工具.我采用微软提供的打包工具: InstallShield2015LimitedEdition.下载地址:https://msdn.micr ...
- 从网上找的 visual studio 的各个版本下载地址,vs2010/vs2012/vs2013带注册码
从网上找的 visual studio 的各个版本下载地址,很全,从 6.0 一直 到 vs2013,要的拿去吧... Microsoft Visual Studio 6.0 下载:英文版360云盘下 ...
- VS2012 Unit Test 个人学习汇总(含目录)
首先,给出MSDN相关地址:http://msdn.microsoft.com/en-us/library/Microsoft.VisualStudio.TestTools.UnitTesting.a ...
- VS2012 Unit Test —— 我对IdleTest库动的大手术以及对Xml相关操作进行测试的方式
[1]我的IdleTest源码地址:http://idletest.codeplex.com/ [2]IdleTest改动说明:2013年10月份在保持原有功能的情况下对其动了较大的手术,首先将基本的 ...
- VS2012 Unit Test——Microsoft Fakes入门
如题,本文主要作为在VS2012使用Fakes的入门示例,开发工具必须是VS2012或更高版本. 关于Fakes的MSDN地址:http://msdn.microsoft.com/en-us/libr ...
- 在Qt Creator 和在 vs2012 里添加信号和槽
原文地址:http://www.cnblogs.com/li-peng/p/3644812.html 作者:李鹏 出处:http://www.cnblogs.com/li-peng/ 本文版权归作者和 ...
- vs2012 安装entity framework
1.安装vs2012 2.打开vs2012的工具下的扩展工具 3.搜索nuget,没安装的直接在线安装 4.安装好了NuGet,程序包管理器控制台 5.执行命令Install-Package Enti ...
随机推荐
- Failed to load class “org.slf4j.impl.StaticLoggerBinder”
背景: 在配置使用Hibernate的时候遇到了这个问题, 然后就很头疼. SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerB ...
- Python 面向对象 特殊方法(魔法方法)
Python 的特殊方法,两边带双下划线的方法. 比如:__init__(self, ...).__del__(self) 1.__init__(self,...) : 构造方法 __init__(s ...
- c++的if语句中的110为什么不等于110?
从上图可以看出,当表达式1.1*x被直接放进if的判断括号中时1.1*x不等于y,但是将1.1*x赋值给z时,z与y相等,这是为什么?(以下为不等价时的代码) #include<stdio.h& ...
- Ubuntu 和 centos7 服务的启动
Ubuntu 下: /etc/init.d/nginx start | stop | reload Centos7下: service nginx start | stop | reload
- 文本三剑客之grep
接受正则表达式,按行匹配,将会过滤出匹配的所有行 格式: grep [OPTION]... PATTERN [FILE]... 可以看出,grep后可以同时接多个文件 选项OPTIO ...
- svn搭建脚本
1.yum install subversion 2.输入rpm -ql subversion查看安装位置 我们知道svn在bin目录下生成了几个二进制文件. 输入 svn --help可以查看svn ...
- virsh 命令
virsh是用与管理虚拟化环境中的客户机和Hypervisor的命令行工具,与virt-manager等工具类似,也是调用libvirt API来实现虚拟化的管理. 在使用virsh命令行进行虚拟化管 ...
- 队列的JS实现及广度优先搜索(BFS)的实现
队列是先进先出(FIFO)的数据结构,插入操作叫做入队,只能添加在队列的末尾:删除操作叫做出队,只能移除第一个元素.在JS中,用数组可以很简单的实现队列.JavaScript实现排序算法 functi ...
- windows 上使用virtualenv进行python多版本转换
近期因为需要在python2.7和Python3.6上进行工作学习,可是笔记本只配置了python3.6环境. 所以打算使用virtualenv这个强大的工具进行多版本转换: 一.首先,默认已经配置好 ...
- python-字典数据类型内置方法
字典数据类型内置方法(必考) 用途:存多个值,不通过索引取值,可以用关键字找到对应得值 定义方式:{}内以key:value的方式存储多个值,值与值之间用逗号隔开 lis = ['ruixing', ...