在一组数据当中我们取出一个我们想要的数据的过程,谓之查找。

1、简单查找:

  需求:在一组数据当中找到你想要的一个数据,并且返回该数据在数组当中的索引。

  思路:循环遍历整个数组,然后拿各个元素与所要找出的数字做比较,如果相等返回该位置的索引,相反如果查找完之后,仍没有找到数据,此时就返回-1,表示该数据不再数组当中。

  代码:

class SimpleFind
{ public static void main(String [] args)
{ int[] arr = {1,3,89,43,6,80};
System.out.print(simpleFind(arr,3)); } public static int simpleFind(int [] arr,int key)
{ for(int i = 0; i<arr.length ; i++)
{ if(arr[i] == key)
return i;
continue; } return -1; } }

  但是这种方法相对来说有些低效,下面我们介绍一种比较高效的一种方法。

  思路:假如现在我们要查找一个数在一个已经排序好了的数组中。较之第一种方法,我们先拿我们要找的数字与数组中间的数字做比较,如果数字大于中间的数字,此时我们数字肯定不再中间数字的左边了,但是可能存在于数字右边。我们再拿要找的数字与右边一半的数字做比较,如果大于则继续查找右边的那一半,否则查找左边的另一半。周而往复,直至查找到,返回索引值,否则返回-1,表示数组当中不存在这个数字。

  

  

class BinarySearch
{ public static void main(String[] args)
{ int[] arr = {1,4,7,8,13,24,56,99};
//System.out.print(binarySearch(arr,13));
System.out.print(binarySearch2(arr,56)); } public static int binarySearch(int[] arr, int key)
{ int mid = (arr.length-1)>>>1;
//System.out.print(mid);
int min = 0;
int max = arr.length-1;
//System.out.print(min<max);
while(min<=max)
{
if(arr[mid]>key){
max = mid-1;
mid = (min+max)>>>1;
}else if(arr[mid]<key){
min = mid+1;
mid = (max+min)>>>1;
}else{
return mid;
}
//System.out.println("min = "+min+" "+"max = "+max); }
return -1; }
public static int binarySearch2(int[] arr, int key)
{ int mid = (arr.length-1)>>>1;
//System.out.print(mid);
int min = 0;
int max = arr.length-1;
//System.out.print(min<max);
while(arr[mid] != key)
{
if(arr[mid]>key){
if(max<min)
return -1;
max = mid-1;
mid = (min+max)>>>1;
}else{
if(max<min)
return -1;
min = mid+1;
mid = (max+min)>>>1;
}
//System.out.println("min = "+min+" "+"max = "+max);
}
return mid; }
}

  

java学习之查找的更多相关文章

  1. (私人收藏)[开发必备]最全Java离线快速查找手册(可查询可学习,带实例)

    (私人收藏)[开发必备]最全Java离线快速查找手册(可查询可学习,带实例) https://pan.baidu.com/s/1L54VuFwCdKVnQGVc8vD1TQnwmj java手册 Ja ...

  2. 0032 Java学习笔记-类加载机制-初步

    JVM虚拟机 Java虚拟机有自己完善的硬件架构(处理器.堆栈.寄存器等)和指令系统 Java虚拟机是一种能运行Java bytecode的虚拟机 JVM并非专属于Java语言,只要生成的编译文件能匹 ...

  3. 《Java学习笔记(第8版)》学习指导

    <Java学习笔记(第8版)>学习指导 目录 图书简况 学习指导 第一章 Java平台概论 第二章 从JDK到IDE 第三章 基础语法 第四章 认识对象 第五章 对象封装 第六章 继承与多 ...

  4. Java学习之路:不走弯路,就是捷径

    1.如何学习程序设计? JAVA是一种平台,也是一种程序设计语言,如何学好程序设计不仅仅适用于JAVA,对C++等其他程序设计语言也一样管用.有编程高手认为,JAVA也好C也好没什么分别,拿来就用.为 ...

  5. Java学习第一天

    Java学习第一天 对于网络管理员或者黑客必须知道的八个cmd命令 详情请参考:http://www.2cto.com/os/201608/533964.html          nbtstat  ...

  6. 20145304 第五周Java学习报告

    20145304<Java程序设计>第5周学习总结 教材学习内容总结 1.使用try.catch: 如果使用了try.catch,编译时会尝试执行try区块中的程序代码,如果有错误,执行流 ...

  7. 20145330第九周《Java学习笔记》

    20145330第九周<Java学习笔记> 第十六章 整合数据库 JDBC入门 数据库本身是个独立运行的应用程序 撰写应用程序是利用通信协议对数据库进行指令交换,以进行数据的增删查找 JD ...

  8. Java学习-043-获取文件在目录中的路径

    我们在日常的电脑使用中,经常需要在当前目录或当期目录及其子目录中查找文件,并获取相应的文件路径名.在我们的自动化测试中,也经常需要确认文件在目录中是否成功生成或已存在,因而我写了一个小方法来实现. 获 ...

  9. Java学习-024-获取当前类名或方法名二三文

    今天,看朋友编写程序,打印日志时,需要记录当前类的类名以及当前方法的方法名,我发现 TA 将类名或者方法名直接写死在了代码中...虽说这样可以实现记录类名和方法名,但是当有特殊情况需要修改类名或者方法 ...

随机推荐

  1. CentOS iSCSI客户端使用配置

    配置步骤: 1.查看安装是否安装iSCSI驱动 rpm -qa|grep iscsi 2.查看yum安装源 yum list |grep iscsi 3.安装iscsi驱动 yum install i ...

  2. MapReduce实战:查找相同字母组成的单词

    1.项目需求 一本英文书籍包含成千上万个单词,现在我们需要在大量的单词中,找出相同字母组成的所有单词 2.数据集 下面是一本英文书籍截取的一部分单词内容(书籍内容是随意写的,主要目的是实现这种需求) ...

  3. oracle实现自动记录存储过程、自定义函数执行错误

    CREATE OR REPLACE Package Pkg_Stm_Prgerrlog As --Purpose: 实现记录系统错误异常信息,便于问题跟踪 Procedure Sp_Stm_Prger ...

  4. Castle Windsor Fluent Registration API

    一对一注册 直接注册组件 container.Register( Component.For<MyServiceImpl>() ); 注册接口并提供组件 container.Registe ...

  5. 设计模式学习——准备(UML类图)

    前言 其实吧,最早接触UML是源于软件设计师的考试,半路出家实在难为我了.学设计模式总是要画类图的,所以补充UML的类图的知识是很重要滴.第一篇就偷懒一点copy别人的东西了.实话说,我们都是踩在巨人 ...

  6. Android Studio创建工程时一直卡在下载Gradle

    一直提示这个进度条,查了不少资料,有的说FQ,有的说下载gradle后运行下bin里面的批处理,再在环境变量里Path中加入路径,我都试了,都不和... 按理说FQ了可以下载了吧,但是半天没下载完,一 ...

  7. Content Providers

    Content providers manage access to a structured set of data. They encapsulate the data, and provide ...

  8. SQL觸發器聯級刪除

    Create TRIGGER [dbo].[trigInstructionsDelete] ON dbo.Instructions instead OF DELETE AS BEGIN DECLARE ...

  9. 搞一个app需要多久?

    //转载文章,看后有感 我有些尴尬地拿着水杯,正对面坐着来访的王总,他是在别处打拼的人,这几年据说收获颇丰,见移动互联网如火如荼,自然也想着要进来干一场,尽管王总从事的行当也算跟IT沾边,但毕竟太长时 ...

  10. IO流基础

    IO流,也称为数据流,用于处理设备之间的数据传输. JAVA对数据的操作就是通过流的方式,而流分为两种:字符流,字节流 字符流: 可以内部制定码表,处理文字很方便,字符流里的基类是Reader,Wri ...