java - 对字符串数组进行二分查找时遇到问题

标签 java search binary-search

在我的程序中,我将文件中的 20 个名称存储到一个数组中。然后,用户可以输入名称,并使用二分搜索来查找位置。我的程序似乎无法将目标与数组中点匹配。我尝试过修剪任何空白,但仍然没有成功。 搜索算法看起来没问题吗?

while(true){
            System.out.println("Enter the name you are searching for.");
            String target = sc.nextLine();
            if(target.equals("done"))
                break;
            int mid;
            int left = 0;
            int right = names.length-1;
            while(left <= right){
                mid = (left + right)/2;
                if(target.equals(names[mid].trim())){
                    System.out.println("Found in position: " + mid);    //when found
                    break;
                }
                else if(target.compareTo(names[mid]) < 0){       //set right parameter
                    right = mid-1;
                }
                else if(target.compareTo(names[mid]) > 0){      //set left parameter
                    left = mid+1;    
                }         
            }
        }

最佳答案

也许你也应该修剪目标?

if(target.trim().equals(names[mid].trim())){
                System.out.println("Found in position: " + mid);    //when found
                break;
            }

关于java - 对字符串数组进行二分查找时遇到问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20257868/

相关文章:

java - Hibernate - 重复键上的自动填充记录 ID

使用关键字的 SQL 搜索查询

php - 无法理解 C++ STL 源中的 1 行代码 : Lower_Bound/Upper_Bound

java - 使用模式在 Java 中重构重复代码

java - 我的 JavaFX 计时器不工作。为什么?

Python 在 CSV 中搜索一列中的字符串,从同一行中的另一列返回字符串

html - 带有 Logo 、搜索表单和按钮的标题打破了响应式设计

c - 如何用更少的迭代找到最大值

Python 类似二进制搜索的函数,用于查找排序列表中大于特定值的第一个数字

java - 如何在不离开jsp的情况下从servlet返回消息?