我发现了这个:https://github.com/thetron/StringScore/blob/master/NSString%2BScore.m – 但不幸的是它很慢.我需要将其与大约200个字符串进行比较,并且它是连续的 – 每次键入新键击.
有任何想法吗?
解决方法 如果Nsstring score做你想要的但速度太慢,你可以从加速它开始.第23至28行 – -scoreAgainst:模糊:选项:设置代码只需要进行一次,而不是每次进行200次比较.因此,将该代码拉入设置方法并再次测量.编辑:
作为练习,我forked StringScore,提取设置代码并进行最小的更改以获得一些性能改进,然后测量它.我使用了1000个随机单词,将它们分成三个(例如“中断点饮用”).对于这些组中的每一组,我进行了设置(如本原始答案中所述),然后将字符串与所有1000组进行比较.我的Core 2 Duo大约需要11秒.
因此,将一个字与1000比较大约需要11毫秒.现在你只需要1到200,所以它可能不到10毫秒.这对你有用吗?
(顺便说一句,将近一半的时间仍然花在rangeOfString上:找到一个单个字符;这可能要快得多,但我不想深入了解算法的细节.)
总结以上是内存溢出为你收集整理的Objective-c:快速模糊搜索匹配全部内容,希望文章能够帮你解决Objective-c:快速模糊搜索匹配所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)