栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

在TreeSet中即时搜索记录

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

在TreeSet中即时搜索记录

如果要查找所有以文本开头的条目(例如“ f”),则可以使用如下

subSet(from, to)
方法:

SortedSet<String> s = new TreeSet<String>(new Comparator<String>() {  public int compare( String s1, String s2 ) {    return s1.compareToIgnoreCase( s2 );  }});s.add( "Erich" );s.add( "Erica" );s.add( "Erin" );s.add( "Dave" );s.add( "Thomas" );SortedSet<String> result = s.subSet( "e", "e" + Character.MAX_VALUE ); //"e" represents the user inputSystem.out.println(result);//prints [Erica, Erich, Erin]result = s.subSet( "Eric", "Eric" + Character.MAX_VALUE );System.out.println(result); //prints [Erica, Erich]result = s.subSet( "Erich", "Erich" + Character.MAX_VALUE );System.out.println(result); //prints [Erich]

由于

to
to 的参数
subset(from,to)
是排他的,因此您需要的东西显然会更大。在我的示例中,我只是添加了一个,
Character.MAX_VALUE
但是您可能希望获得更好的上限。请注意,这取决于您的比较器,例如,它如何处理大小写差异等。

如果您想使用通配符进行过滤,例如 包含
该文本的所有文本(例如,

f
将转换为
*f*
),则必须遍历并检查所有条目。在这种情况下,使用排序集不会获得任何好处。

编辑:将示例更新为您的数据(也添加了我:))。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/464291.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号