ios – 快速搜索和排序

ios – 快速搜索和排序,第1张

概述我整个下午一直在研究搜索算法,我想要一些意见.我正在做的一些是特定于iOS的,但一般概念不是. 我正在尝试显示一组数据,一个目录.在目录中我有部门和人员.我知道这听起来像是一本教科书的例子,听我说.我保证,这不是家庭作业. (我可以提供我正在处理的截图.) 我有一系列条目,其中有两种目录条目.我需要按名称对条目进行排序,然后将数组拆分为更小的数组,其中每个子数组包含以相同字母开头的条目. 此外,我 我整个下午一直在研究搜索算法,我想要一些意见.我正在做的一些是特定于iOS的,但一般概念不是.

我正在尝试显示一组数据,一个目录.在目录中我有部门和人员.我知道这听起来像是一本教科书的例子,听我说.我保证,这不是家庭作业. (我可以提供我正在处理的截图.)

我有一系列条目,其中有两种目录条目.我需要按名称对条目进行排序,然后将数组拆分为更小的数组,其中每个子数组包含以相同字母开头的条目.

此外,我需要考虑用户可能输入的搜索字符串.

我的一般过程是这样的:

>筛选与类型匹配的所有条目和搜索字符串(如果有).对于此步骤,我使用nspredicate:

nspredicate *predicate = [nspredicate predicateWithFormat:@"type == %i AND searchableContents B[cd] %@",type,searchString];if (!searchString || searchString.length == 0){    predicate = [nspredicate predicateWithFormat:@"type == %i",type];}NSArray *array = [_directoryContents filteredArrayUsingPredicate:predicate];

>按字母顺序对结果进行排序.

array  = [array sortedArrayUsingComparator:^NSComparisonResult(ID obj1,ID obj2) {    return [((BRKDirectoryEntry *)obj1).comperableTitle compare:((BRKDirectoryEntry *)obj2).comperableTitle];}];

>将结果分解为更小的数组.为了提高性能,如果我们正在搜索,我会跳过此步骤,但它似乎没有帮助.

if(Alphabetized){    array = [self _AlphabetizedArrayFromPresortedArray:array];}

总共950个条目的表现非常糟糕.

现在,对于我的默认显示,我可以简单地将已排序的数据缓存在内存中,然后显示和滚动效果很好,但对于I类搜索,根本无法实现用户期望的平滑性能.

任何指针或提示?

解决方法 是.忘记文件并将其保存在数据库中.创建索引Everything成为一个简单的SQL语句. 总结

以上是内存溢出为你收集整理的ios – 快速搜索和排序全部内容,希望文章能够帮你解决ios – 快速搜索和排序所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/web/1024445.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-05-23
下一篇2022-05-23

发表评论

登录后才能评论

评论列表(0条)

    保存