javascript - 二分搜索循环
问题描述
我必须对打字稿中的名称目录进行二进制搜索,如果名称在数组中,则代码可以正常工作,但如果名称不在数组中,它就会陷入无限循环。
有人可以帮助我吗?请!这是代码:
var initialArray = ['Diego', 'David','Mauricio']
var sortedArray = initialArray.sort()
function search(find) {
var leftLimit = initialArray[0]
var leftLimitIndex = initialArray.indexOf(leftLimit)
var rightLimit = initialArray[initialArray.length - 1]
var rightLimitIndex = initialArray.indexOf(rightLimit)
var pivotIndex = 0
var index = -1
while (compare(leftLimit, rightLimit)) {
pivotIndex = Math.floor((leftLimitIndex + rightLimitIndex)/2)
console.log(pivotIndex)
if (initialArray[pivotIndex] == find) {
index = pivotIndex
break
}
else {
if (compare(initialArray[pivotIndex], find)) {
leftLimitIndex = pivotIndex + 1
}
else {
rightLimitIndex = pivotIndex - 1
}
}
console.log(initialArray[pivotIndex])
}
console.log("Result: "+initialArray[index])
return initialArray[index]
}
function compare(leftLimit, rightLimit) {
var r = (leftLimit < rightLimit ? -1 : 1)
if (r < 0) {
return true
}
else {
return false
}
}
解决方案
您没有考虑更改的限制索引,最后您不知道您是否没有更多的搜索选项,或者 findTerm 是否根本不存在。您只需要更改以下行
while (compare(leftLimit, rightLimit) && leftLimitIndex <= rightLimitIndex) {
问候,
推荐阅读
- android - Espresso 测试因以下原因而失败:androidx.test.espresso.AppNotIdleException。以下空闲条件失败 MAIN_LOOPER_HAS_IDLED
- arrays - 优化读取语句
- loopback4 - loopback4 中内置模型的可用性
- c# - 在 Linq Lambda 中转换 mysql
- vue.js - 在 v-for 循环中使用 v-model
- git - 计算从特定分支创建的分支数
- activemq-artemis - 如何识别连接?
- spring-boot - Swagger 不会添加新的 api 控制器来休息(Spring 启动)
- phpmyadmin - phpmyadmin 配置程序在中止后不启动(LEMP,Ubuntu 20.04)
- javascript - 覆盖 console.log 时如何显示 Promise 对象的状态和值