RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1113752
Accepted
Str
Str
Asked:2020-04-22 05:38:49 +0000 UTC2020-04-22 05:38:49 +0000 UTC 2020-04-22 05:38:49 +0000 UTC

查找数组中的所有元素

  • 772

我在网上找不到的问题(这并不奇怪,因为很多人使用现成的方法)是如何使用二进制搜索找到数组中所有相同的元素?如果我将二进制搜索限制for-ом在找到的第一个元素并通过提高左“底部”直到返回“”来“遍历”二进制搜索,那么二进制搜索是否会是二进制的нет найденных элементов?

或者它可以以其他方式完成而不诉诸于for?告诉!

搜索最左边的元素 -

public static int binary_search_leftmost(int[] A,int n,int T) {
        int L = 0;
        int R = n;
        while (L < R) {
            int m = ((L + R) / 2);
            if (A[m] < T){
                L = m + 1;
            } else {
                R = m;
            }
        }
        return L;
}
    public static void main(String [] args) {
        int[] arr = {1,2,3,4,5,5,5,5,6,6,6,7,7,7,7,8,8,8,8,9,9,9};
        System.out.println(binary_search_leftmost(arr,17,5));
    }

添加 -

static int binarySearchR(String[] arr, String x) 
    { 
        int l = 0, r = arr.length - 1; 
        while (l < r) { 
            int m = l + (r - l) / 2; 

            int res = x.compareTo(arr[m]); 

            if (res == 0) 
                return m; 

            if (res < 0) 
                r = m - 1;

            else
                 l = m + 1; ; 
        } 

        return -1; 
    } 

我不明白如何修复它以便找到最右边的元素..如果元素是2,那么它会找到第二个,但是如果有3个或更多元素,那么该方法仍然只找到第二个元素第一个 .. 例如:{"aa","aa","aa","aa","bb","bb"}- 该方法查找索引为 1 的元素,需要查找索引为 3 的元素

java
  • 1 1 个回答
  • 10 Views

1 个回答

  • Voted
  1. Best Answer
    MBo
    2020-04-23T23:14:18Z2020-04-23T23:14:18Z
    public static int BSL(String A[], String key) 
    { 
        int m; 
        int l = 0, r = A.length; 
    
        while( r > l ) 
        { 
            m = l + (r - l)/2; 
    
            if( A[m].compareTo(key) < 0 ) 
                l = m + 1; 
            else
                r = m; 
        } 
    
        return l; 
    } 
    
    public static int BSR(String A[], String key) 
    { 
        int l = 0, r = A.length; 
        int m; 
    
        while( r > l) 
        { 
            m = l + (r - l)/2; 
    
            if( A[m].compareTo(key) > 0 ) 
                r = m; 
            else
                l = m + 1; 
        } 
        return r - 1; 
    
    }
    
        public static void main (String[] args) throws java.lang.Exception
        {
           String[] arr = {"aa","aa","bb","bb","bb","cc","cc"};
           int l = BSL(arr, "bb");
           int r = BSR(arr, "bb");
           System.out.println(l);
           System.out.println(r);
    
        }
    

    ideone

    2
    4
    

    在第二次搜索中通过已经找到的左边缘稍微有利可图。

    • 1

相关问题

  • wpcap 找不到指定的模块

  • 如何以编程方式从桌面应用程序打开 HTML 页面?

  • Android Studio 中的 R.java 文件在哪里?

  • HashMap 初始化

  • 如何使用 lambda 表达式通过增加与原点的距离来对点进行排序?

  • 最大化窗口时如何调整元素大小?

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    如何从列表中打印最大元素(str 类型)的长度?

    • 2 个回答
  • Marko Smith

    如何在 PyQT5 中清除 QFrame 的内容

    • 1 个回答
  • Marko Smith

    如何将具有特定字符的字符串拆分为两个不同的列表?

    • 2 个回答
  • Marko Smith

    导航栏活动元素

    • 1 个回答
  • Marko Smith

    是否可以将文本放入数组中?[关闭]

    • 1 个回答
  • Marko Smith

    如何一次用多个分隔符拆分字符串?

    • 1 个回答
  • Marko Smith

    如何通过 ClassPath 创建 InputStream?

    • 2 个回答
  • Marko Smith

    在一个查询中连接多个表

    • 1 个回答
  • Marko Smith

    对列表列表中的所有值求和

    • 3 个回答
  • Marko Smith

    如何对齐 string.Format 中的列?

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5