首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >CaseInsensitive搜索在HashMap中的应用

CaseInsensitive搜索在HashMap中的应用
EN

Stack Overflow用户
提问于 2015-10-06 05:56:04
回答 2查看 1.8K关注 0票数 0

我有一张地图:

代码语言:javascript
复制
static Map<String, String> = getMap(); //getting a map from a config file.

现在,在这个地图中,我需要使用键执行caseInsensitive搜索。我不是将值放在map中,也不是通过put函数,但您可以将其视为以键值格式存储在数据库中的值,并将其作为Map检索。我需要做一个caseInsentive搜索。

经过研究,使用TreeMap可以解决这个问题,但效率不高-> O(log )

或者过度使用HashMap的get()方法,创建自己的HashMap。但是这将包括过多的方法,我不想要这么多,它不是非常重要的代码的一部分。

现在,我正在存储这些值,以小写形式存储在数据库中,并进行检查。但这使得它在数据库中容易出错,而且不容易读懂。

有更简单的方法来做吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-10-06 06:09:10

1. TreeMap扩展Map是一种选择,但时间复杂性是O(log n)

代码语言:javascript
复制
final Map<String, Object> map = new TreeMap<String, Object>(String.CASE_INSENSITIVE_ORDER);

2.)您可以像上面建议的那样使用中的CaseInsensitiveMap

3.)创建自己的HashMap类和重写方法。

代码语言:javascript
复制
public class MyCaseInsensitiveMap extends HashMap<String, String> {
    ...
    put(String key, String value) {
       super.put(key.toLowerCase(), value);
    }

    get(String key) {
       super.get(key.toLowercase());
    }
}

4.)您需要一个带有不区分大小写的equals()hashCode()实现的字符串键的包装类。用它代替Map键的字符串。

示例这里

**除了apache之外,似乎没有直接的库可供使用。

PS:合并自其他链接,在此也可用。

票数 4
EN

Stack Overflow用户

发布于 2015-10-06 06:11:04

如果您对O(1)没有意见,但需要更多的空间,这可能会有所帮助:

代码语言:javascript
复制
class CaseInsensitiveLookupMap {

private Map<String,String> keysMap = new HashMap<String,String>();
private Map<String,String> dataMap;

public CaseInsensitiveLookupMap(Map<String,String> dataMap){
  this.dataMap=dataMap;
  for(String key: dataMap.keySet()){
     keysMap.put(key.toLowerCase(),key);
  }
}

public String get(String keyToSearch){
  String _key = keysMap.get(keyToSearch.toLowerCase());
  if(_key!=null) {
    return dataMap.get(_key);
  }
  return null;
}

}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/32962689

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档