各位用户为了找寻关于想全面了解Lookup函数,必须要懂二分法的资料费劲了很多周折。这里教程网为您整理了关于想全面了解Lookup函数,必须要懂二分法的相关资料,仅供查阅,以下为您介绍关于想全面了解Lookup函数,必须要懂二分法的详细内容

当你懂了lookup的查找原理,才能更好的使用它。二分法原理,一起学习一下。

从一个例子说起:

【例】下图中两个表只有第5行的会员名字有差异,在查找B的消费金额时,显示结果却不同,而左边直接出现A的消费金额。

公式展示:

B11 =LOOKUP(A11,A2:B8)

E11 =LOOKUP(D11,D2:E8)

如果有12个数呢,则第6个位置是二分位。有一个公式可以计算。

=INT((总行数+1)/2)

2、查找方向确定

当在二分位查找不到时,接下来该怎么操作呢?

如果上一次二分位值大于查找的值时,则向上接着查找,找出新的二分位,直到找出对应的值。如下图。

如果二分值等于查找的值,向下逐个查,直到相邻且相等的值即符合条件。

过徎展示:

第一步:从第1个二分位处(对应A4)处开始查找,200<350,则向下查找。

第二步:在第2个二分位处(对应A6)的值400>350,则要向上查,只有A5一个值300,因该值小于350,所以B5即为最终查找结果。

2、查找最后一个。

【例2】如下图,查找A最后一次的消费金额。

分析:

这里肯定不能直接用Lookup查找B,否则按二分位查找,结果不一定是最后一个。所以就用0除的方法把符合条件的变成0,不符合条变成错误值:

=0/(A2:A8=A11)

结果是

{0;0;#DIV/0!;#DIV/0!;0;#DIV/0!;#DIV/0!}

由于lookup会过滤掉错误值,所以在lookup眼中,上面的数组是这样的:

{0;0;0}

然后用1查找最后一个0的位置

=Lookup(1,0/(A2:A8=A11),B2:B8)

这里1是任一个大于0的值,因为大于0,所以用二分法查找时,会一直向下查找,直到最后一个0值。

lookup的二分法查找,是跳跃式的查找。它总认为被查找的1组值是从小到大排列,如果遇到小的就向下找更大的,如果遇到大的就向上找更小的。