java二分法查找怎么实现
BinarySearch
二分法查找,顾名思义就是要将数据每次都分成两份然后再去找到你想要的数据,
我们可以这样去想,二分法查找很类似与我们平时玩的猜价格游戏,当你报出一个价格时裁判会告诉你价格相对于真实值的高低,倘若是低了那我们一定会再说出一个略高的价格,反之亦然。
(相关视频教程分享:java视频教程)
在二分法查找时要求传入的数据必须已经有序,假设现在为升序,然后每次将所寻找的值与中间值(数组左边界+(右边界-左边界)/2)作比较,大了则去寻找中间值左侧数据,小则寻找中间值右侧数据。
public class BinarySearch { //进行二分法查找的前提是数组已经有序! public static int rank(int key,int nums[]) { //查找范围的上下界 int low=0; int high=nums.length-1; //未查找到的返回值 int notFind=-1; while(low<=high) { //二分中点=数组左边界+(右边界-左边界)/2 //整数类型默认取下整 int mid=low+(high-low)/2; //中间值是如果大于key if(nums[mid]>key) { //证明key在[low,mid-1]这个区间 //因为num[mid]已经判断过了所以下界要减一 high=mid-1; }else if(nums[mid]<key) { //证明key在[mid+1,high]这个区间 //同样判断过mid对应的值要从mid+1往后判断 low=mid+1; } else { //查找成功 return mid; } } //未成功 return notFind; } public static void main(String[] args) { System.out.println("请输入数据数量:"); Scanner scanner=new Scanner(System.in); int amount=scanner.nextInt(); int num; int nums[]=new int[amount]; int i=0; while(i<amount) { nums[i]=scanner.nextInt(); i++; } Arrays.sort(nums); System.out.println("请输入想要查找的值"); int key=scanner.nextInt(); int answer=rank(key,nums); if(answer!=-1) { System.out.println("所查找的数据存在:"+nums[answer]); } else { System.out.println("您所查找的数据不存在"); } } }
更多java教程,请关注PHP中文网Java教程栏目。
以上是java二分法查找怎么实现的详细内容。更多信息请关注PHP中文网其他相关文章!

Java主要用于构建桌面应用、移动应用、企业级解决方案和大数据处理。1.企业级应用:通过JavaEE支持复杂应用,如银行系统。2.Web开发:使用Spring、Hibernate简化开发,SpringBoot快速搭建微服务。3.移动应用:仍是Android开发主要语言之一。4.大数据处理:Hadoop和Spark基于Java处理海量数据。5.游戏开发:适用于中小型游戏开发,如Minecraft。

如何将Java开发工具设置为中文界面?可以通过以下步骤实现:Eclipse:Window->Preferences->General->Appearance->I18nsupport->Language->Chinese(Simplified),然后重启Eclipse。IntelliJIDEA:Help->FindAction->输入"switchlanguage"->选择"SwitchIDELanguage&q

学习Java并达到工作水平通常需要6到12个月,对于有编程基础的人可能缩短至3到6个月。1)零基础学习者需6-12个月掌握基础和常用库。2)有编程基础者可能3-6个月内掌握。3)就业时间在学习9-18个月后,实际项目和实习可加速进程。

在Java中,new操作符用于创建对象,其过程包括:1)在堆内存中分配空间,2)初始化对象,3)调用构造函数,4)返回对象引用。理解这些步骤有助于优化内存使用和提升应用程序性能。

在Java中定义数组的语法是:1.数据类型[]数组名=new数据类型[数组长度];2.数据类型数组名[]=new数据类型[数组长度];3.数据类型[]数组名={元素列表};数组是对象,可为null,下标从0开始,使用时需注意潜在的错误如NullPointerException和ArrayIndexOutOfBoundsException。

new关键字在Java中用于创建对象实例。1)它告诉JVM分配内存并调用构造函数初始化对象。2)使用new可以强制创建新对象,即使内容相同。3)构造函数允许自定义初始化。4)频繁使用new可能导致性能问题和内存泄漏。5)需要使用try-catch处理可能的异常。6)匿名内部类是new的高级用法。

解决Java中的中文乱码问题可以通过以下步骤:1.设置正确的字符编码,如UTF-8或GBK,确保文件、数据库和网络通信使用相同编码。2.使用Java的字符编码转换类进行必要的编码转换。3.通过调试工具和日志验证编码是否正确,确保在不同环境下中文显示正常。

Java中的异常分为检查型异常和非检查型异常。检查型异常必须显式处理,否则编译器报错,常用于可恢复错误,如文件未找到;非检查型异常无需显式处理,常用于编程错误,如空指针异常。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

SublimeText3 Linux新版
SublimeText3 Linux最新版

SublimeText3 英文版
推荐:为Win版本,支持代码提示!

记事本++7.3.1
好用且免费的代码编辑器

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。