我的编程空间,编程开发者的网络收藏夹
学习永远不晚

怎么在java中利用二分法寻数组的位置

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

怎么在java中利用二分法寻数组的位置

怎么在java中利用二分法寻数组的位置?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

Java的特点有哪些

Java的特点有哪些1.Java语言作为静态面向对象编程语言的代表,实现了面向对象理论,允许程序员以优雅的思维方式进行复杂的编程。2.Java具有简单性、面向对象、分布式、安全性、平台独立与可移植性、动态性等特点。3.使用Java可以编写桌面应用程序、Web应用程序、分布式系统和嵌入式系统应用程序等。

1、二分法说明

二分法的核心思想就是索引的移动,查找速度是几何级递增的。

二分查找法,返回查找到数组元素的索引,如果找不到返回-1

2、实例

二分法定位参数值在数组中的位置

场景描述:

根据一个参数值找到它在数组内的下标区间,例如: 2在数组{0,1,3,5}的区间为{1,2}

package com.study.collection; import java.util.Arrays; public class ExampleList<T> {     public static void main(String[] args) {        int[] intArray = {0,1,2,10,15,20,25,29,31,36,39,40,42,43,46,50,55,60,63,66,70};        int num =2;        int[] resultArray = getPostionByTwoPoint(intArray, num);        System.out.println(Arrays.toString(resultArray));    }     private static int[] getPostionByTwoPoint(int[] intArray, int num) {        // 判断        if(intArray == null || intArray.length == 0){            throw new RuntimeException("数组不能为空");        }        // 定义最小和最大区间        if(intArray[0] > num || intArray[intArray.length - 1] < num){            throw new RuntimeException("不在数组范围之内");        }         int middle = 0;        int low = 0;        int high = intArray.length - 1;        // 定义首尾特殊的情况        if(intArray[low] == num){            int[] resultArray = {low, low};            return resultArray;        }else if(intArray[high] == num){            int[] resultArray = {high, high};            return resultArray;        }        int i = 1;        // 数在中间的情况        while(low < high){            System.out.println("查找第 " + i + " 次");            middle = (low + high + 1)/2;            if(intArray[middle] == num){                int[] resultArray = {middle, middle};                return resultArray;            }else if(intArray[middle] > num){                // num 在 low 和 middle 之间                int previous = middle - 1;                if(previous > low  && intArray[previous] < num){                    int[] resultArray = {previous, middle};                    return resultArray;                }                high = middle;            }else if(intArray[middle] < num){                int latter = middle + 1;                if(latter < high  && intArray[latter] > num){                    int[] resultArray = {middle, latter};                    return resultArray;                }                low = middle;            }            i++;        }        throw new RuntimeException("定位异常");    }}

关于怎么在java中利用二分法寻数组的位置问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注编程网行业资讯频道了解更多相关知识。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

怎么在java中利用二分法寻数组的位置

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

怎么在java中利用二分法寻数组的位置

怎么在java中利用二分法寻数组的位置?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。Java的特点有哪些Java的特点有哪些1.Java语言作为静态面向对象编程语言的代表,
2023-06-14

怎么在java中利用流排序数组

这篇文章给大家介绍怎么在java中利用流排序数组,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。Java的特点有哪些Java的特点有哪些1.Java语言作为静态面向对象编程语言的代表,实现了面向对象理论,允许程序员以优雅
2023-06-14

怎么在java中利用递归实现二分查找

本篇文章给大家分享的是有关怎么在java中利用递归实现二分查找,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。Java有哪些集合类Java中的集合主要分为四类:1、List列表:
2023-06-14

怎么在java中利用二分查找实现迭代

怎么在java中利用二分查找实现迭代?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。Java是什么Java是一门面向对象编程语言,可以编写桌面应用程序、Web应用程序、分布式系统
2023-06-14

怎么在c语言中使用二分法查找数组中的元素

今天就跟大家聊聊有关怎么在c语言中使用二分法查找数组中的元素,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。c语言二分法实现查找数组元素的方法:递归算法#include
2023-06-14

怎么在java中指定二维数组的长度

本篇文章给大家分享的是有关怎么在java中指定二维数组的长度,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。java基本数据类型有哪些Java的基本数据类型分为:1、整数类型,用
2023-06-14

C++中怎么利用LeetCode寻找旋转有序数组的最小值

这篇文章将为大家详细讲解有关C++中怎么利用LeetCode寻找旋转有序数组的最小值,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。[LeetCode] 154. Find Minimum i
2023-06-20

怎么在Java中利用数组模拟循环队列

怎么在Java中利用数组模拟循环队列?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。Java有哪些集合类Java中的集合主要分为四类:1、List列表:有序的,可重复的;2、
2023-06-14

怎么在Linux中利用shell 获去字符串所在行数及位置

怎么在Linux中利用shell 获去字符串所在行数及位置?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。01 获取字符串所在的行数方式一:用grep -n[root@roo
2023-06-09

怎么在Java中利用回溯算法解数独

本篇文章为大家展示了怎么在Java中利用回溯算法解数独,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。一、题干输入一个9*9二维数组表示数独,已经填入的数字用1-9表示,待填入的数字用0表示,试写一个
2023-06-15

数组中的重复数据怎么利用Java去除

今天就跟大家聊聊有关数组中的重复数据怎么利用Java去除,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。一.用List集合实现int[] str = {5, 6, 6, 6, 8, 8
2023-05-31

怎么在java中利用数组实现一个环形队列

本篇文章为大家展示了怎么在java中利用数组实现一个环形队列,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Java是什么Java是一门面向对象编程语言,可以编写桌面应用程序、Web应用程序、分布式系
2023-06-14

利用JS十分钟怎么判断数组中存在元素

这篇文章主要讲解了“利用JS十分钟怎么判断数组中存在元素”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“利用JS十分钟怎么判断数组中存在元素”吧!前言在前端开发中,经常会遇到要判断数组中是否存
2023-06-07

Java中的循环队列怎么利用数组实现

这篇文章将为大家详细讲解有关Java中的循环队列怎么利用数组实现,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。用Java的数组实现一下循环队列。队列的类//循环队列class CirQueu
2023-05-31

R语言怎么在数组中查找特定元素的位置

在R语言中,可以使用which()函数来查找数组中特定元素的位置。下面是一个示例:# 创建一个包含整数的数组arr <- c(1, 2, 3, 4, 5)# 查找元素为3的位置position <- which(arr == 3)#
R语言怎么在数组中查找特定元素的位置
2024-03-06

Java中的排序数索引怎么利用分治算法实现

Java中的排序数索引怎么利用分治算法实现?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。具体如下:/** * Find the first q and return the
2023-05-31

怎么在R语言中利用data.frame实现分组计数和求和

今天就跟大家聊聊有关怎么在R语言中利用data.frame实现分组计数和求和,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。方法1:cnt = table(df$stratum)方法2
2023-06-14

怎么在Java中利用二叉查找树算法实现一个排序功能

这期内容当中小编将会给大家带来有关怎么在Java中利用二叉查找树算法实现一个排序功能,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。具体如下:/** * 无论排序的对象是什么,都要实现Comparable接
2023-05-31

怎么在golang中利用结构体嵌套的切片数组

本篇文章为大家展示了怎么在golang中利用结构体嵌套的切片数组,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。什么是golanggolang 是Google开发的一种静态强类型、编译型、并发型,并具
2023-06-14

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录