gpt4 book ai didi

algorithm - 为什么在 SAP ABAP 中有重复条目的情况下,使用二进制搜索读取表会返回第一个条目?

转载 作者:塔克拉玛干 更新时间:2023-11-03 05:36:40 25 4
gpt4 key购买 nike

二进制搜索适用于排序的条目。根据算法,如果条目数 (n) 是偶数,则它首先搜索第 n/2 个条目。如果它是 key ,则返回它,否则它检查 key 是否小于或大于 n/2 位置。如果它是 less ,那么搜索从索引 1 继续到 n/2 -1,丢弃剩下的一半。类似地重复该过程直到找到搜索到的键。如果条目数为奇数,则中间位置为n-1/2。

所以我的问题是,如果有重复的条目,我们已经按升序对它进行了排序,比如 11122233。现在如果我们使用 key = 1 读取表二分查找(请忽略语法),那么根据算法,n/2 = 4。但第 4 个位置不是 1,因此从 1 继续搜索到第 4 个位置。现在,n/2 = 第二个位置 1,它是关键。所以搜索在第二个索引处停止。所以返回第二个索引。

但是在带有读取表二进制搜索的 abap 中,返回 1 的第一个条目,即索引 1。为什么这样?请解释。

最佳答案

因为算法has been specified and implemented that way :

When the addition BINARY SEARCH is used, if there are multiple hits (due to an incomplete search key or duplicate entries in the table), the first hit according to the order of the rows in the primary index is returned. This is the row with the lowest row number.

这背后的基本原理是,您更喜欢一种表现出稳定行为的语言 - 在表的末尾添加一些完全不相关的条目不应改变 READ TABLE 语句的位置。

关于algorithm - 为什么在 SAP ABAP 中有重复条目的情况下,使用二进制搜索读取表会返回第一个条目?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46251355/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com