首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

关于搜索出来的内容根据权重进行排序

对于这需求要做到百度搜索我呸,谷歌搜索的权重排序,我接到这个需求是拒绝的。后来经过和小伙伴的研究,觉得这个按照权重排序是可以实现的。 下面说一下具体思路。...但是这两个怎么排序呢 还是进行权重排序。...ab1cd的权重 0+1+3+4 = 8 1ab2cd的权重是 1+2+4+5 = 12 那么这两个进行权重排序是ab1cd 1ab2cd 剩下的不满足精确搜索和模糊搜索,应该直接过滤掉的但是考虑到可能这个算法有问题就暂时按照字符串的长度进行排序...对数据源进行按照权重排序之后的数组 @param searchText 搜索的字符串 @return 按照权重排序数组 */ - (NSArray *)sortSearchResultWithSearchText.../** 对搜索出来的结果进行排序 @param list 列表 @return 根据权重排序之后的列表 */ - (NSArray *)

1.4K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    PHP实现堆排序

    不过看在PHP写得还凑合的份上能来实习了,但还是决心恶补一下基础。 其实自己之前也确实感觉到了基础的重要性,一些比较深的东西都比较底层,不学好根本没法进行。...像我之前用PHP做websocket,就牵扯到数据包、数据帧等概念,搞不清楚,连数据都没法处理,还得后来补。...不过幸好我还有一点点数据结构基础,看了点资料也有些明白了,所以想用PHP写一下二叉树的堆排序,顺便也复习下二叉树,堆等数据结构。...堆排序排序求升序用大顶堆,求降序用小顶堆。 本例用求降序的小顶堆来解析。...堆排序PHP实现 //因为是数组,下标从0开始,所以,下标为n根结点的左子结点为2n+1,右子结点为2n+2; //初始化值,建立初始堆 $arr=array(49,38,65,97,76,13,27,50

    1.3K70

    PHP 冒泡排序算法

    什么是冒泡排序 ? ---- 冒泡排序的英文名是 Bubble Sort,是一种最基础的交换排序算法。...相信每个人都喝过汽水吧,在汽水中常有许多的小气泡往上飘,这是因为组成气泡的二氧化糖比水要轻,所以小气泡才会一点一点往上浮,而冒泡排序之所以叫冒泡排序,正是因为这种排序算法的每一个元素都可以像小气泡一样,...冒泡排序算法 ---- 一组无序的数列想要从小到大排序,通过遍历数组,比较相邻的两个元素,当左边的值大于右边的值时,交换双方的值 这是标准的冒泡排序算法,排序过程如下图所示: /** * 冒泡排序算法...) { $tmp = $arr[$j]; $arr[$j] = $arr[$j + 1]; $arr[$j + 1] = $tmp; } } } return $arr; } 推荐文章 ---- 冒泡排序算法

    85230

    哇,ElasticSearch多字段权重排序居然可以这么玩

    背景 读者提问:ES 的权重排序有没有示列,参考参考? 刚好之前也稍微接触过,于是写了这篇文章,可以简单参考下。 在很多复杂的业务场景下,排序的规则会比较复杂,单一的降序,升序无法满足日常需求。...不过 ES 中提供了给文档加权重的方式来排序,还是挺好用的。...,原创文章权重为 100,其他的都为 1,这样原创文章的得分就高于其他类型的文章。...在排序的时候优先得分排序,然后热度排序。就可以得到我们想要的结果了。...scriptFunction 除了使用 weightFactorFunction 来设置权重,另外介绍一种灵活度更高,适用于更复杂的排序场景的方式 scriptFunction。

    3.2K11

    php实现快速排序算法

    理解 每次排序的时候设置一个基准点,将小于等于基准点的数全部放到基准点的左边,将大于等于基准点的数全部放到基准点的右边。...这样在每次交换的时候就不会像冒泡排序一样只能在相邻的数之间进行交换,交换的距离就大得多了。因此总的比较和交换次数就少了,速度自然就提高了。当然在最坏的情况下,仍可能是相邻的两个数进行了交换。...因此快速排序的最差时间复杂度和冒泡排序是一样的,都是 O(N2),它的平均时间复杂度为 O (NlogN)。其实快速排序是基于一种叫做“二分”的思想。不稳定排序 代码实现 <?...php /** * Created by PhpStorm....* User: benny * Date: 18-11-20 * Time: 下午5:01 */ /** * 快速排序 * @param $array * @param $i * @param

    1.1K10

    PHP 排序算法实现讲解

    所谓排序,就是使一串记录,按照其中的某个或某些关键字的大小,递增或递减的排列起来的操作。排序算法,就是如何使得记录按照要求排列的方法。排序 算法在很多领域得到相当地重视,尤其是在大量数据的处理方面。...分别使用插入排序法,冒泡排序法,选择排序法,快速排序法,将下面数组中的值进行按照从小到大的顺序进行排序操作。...$arr(12,43,57,32,51,76,36,91,28,46,40); 1、插入排序法 分析:既定前面数字已经排好顺序,现在要把第n个数字插入到前面有序的数组中,使得这n个数字也是有序的放入其中...分析:从前往后对相邻的两个数字依次进行比较调整,让较大的数字往下沉,让较小的数字往上升,即每相邻的数字进行对比排序,顺序不符合时将其调换位置。...分析:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列

    89250

    PHP的多维数组排序

    熟悉PHP的小伙伴都知道有很多内置函数可以对数组进行排序操作或者自定义一些排序方法(冒泡)等等。 PHP排序函数 sort() 函数用于对数组单元升序排序。...rsort() 函数用于对数组单元降序排序。 asort() 函数用于对数组单元升序排序并保持索引关系。 arsort() 函数用于对数组单元降序排序并保持索引关系。...ksort() 函数用于对数组单元按照键名升序排序。 krsort() 函数用于对数组单元按照键名降序排序。 以上函数都针对的是一维数组的排序。...二维数组排序函数 array_multisort()函数可以对多个数组或多维数组进行排序,或者根据某一维或多维对多维数组进行排序。...// 获取数组中id值 $ids = array_column($sortArr, 'id'); // 第一个参数就是需要排序key的值,传入后相当于先对 $ids 进行排序,然后根据排序后的$ids

    3.7K10
    领券