免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1724 | 回复: 9
打印 上一主题 下一主题

[C++] 请教~~~~~~~~~~~~~~~~~~ [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-09-08 10:10 |只看该作者 |倒序浏览
各位高手 ,我想存储一些数据对,比如(string,othertype),数据中的第一项string没有重复。该用什么结构存储,使得给一个string我就能很快找出其对应的othertype值呢??hashtable??
或者我将string集编号然后存到一个数组里,othertype arr[]??
或者??
......
有没有更好的办法?

论坛徽章:
1
双子座
日期:2015-01-04 14:25:06
2 [报告]
发表于 2008-09-08 10:12 |只看该作者
C++不是有hash_map

论坛徽章:
0
3 [报告]
发表于 2008-09-08 10:18 |只看该作者
你说的是#include <ext/hash_set>?
没怎么用过

论坛徽章:
0
4 [报告]
发表于 2008-09-08 10:19 |只看该作者
最简单的办法,用 std::map

论坛徽章:
1
双子座
日期:2015-01-04 14:25:06
5 [报告]
发表于 2008-09-08 10:20 |只看该作者
原帖由 emacsnw 于 2008-9-8 10:19 发表
最简单的办法,用 std::map

这个不能满足“很快”的需求吧

论坛徽章:
1
双子座
日期:2015-01-04 14:25:06
6 [报告]
发表于 2008-09-08 10:23 |只看该作者
或者用
Trie树

论坛徽章:
0
7 [报告]
发表于 2008-09-08 10:26 |只看该作者
谢谢!
Trie树不熟
我试试map,有问题再回来请教

论坛徽章:
0
8 [报告]
发表于 2008-09-08 10:33 |只看该作者
#include <iostream>
#include <string>
#include <map>
using namespace std;

int main()
{
&nbsp;&nbsp;&nbsp;&nbsp;map<string,int> datas;
&nbsp;&nbsp;&nbsp;&nbsp;datas.insert(pair<string,int>("hello",2));
&nbsp;&nbsp;&nbsp;&nbsp;datas.insert(pair<string,int>("world",3));
&nbsp;&nbsp;&nbsp;&nbsp;cout<<datas["hello"]<<endl;

&nbsp;&nbsp;&nbsp;&nbsp;return 0;
}

能运行,这样可以。
不过为什么编译时有好多警告信息???(VC6下)

论坛徽章:
0
9 [报告]
发表于 2008-09-08 10:49 |只看该作者
我这也报了94的warning

据说是vc的一个bug
编译器内部生成的标识符的长度超过255时将对其进行截断到255字符,因此出现了这个警告。

直接用 #pragma warning(disable:4786) 加在每一个文件开头,警告就全没了。。。

[ 本帖最后由 5毛党党员 于 2008-9-8 10:53 编辑 ]

论坛徽章:
0
10 [报告]
发表于 2008-09-08 10:56 |只看该作者
恩,不错
有警告就是不爽
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP