java数组和集合的元素查找类似,下面以集合为例。

数组集合元素查找分为两类:

  • 基本查找:
  • 二分折半查找:

 基本查找:

两种方式都是for循环来判断,一种通过索引值来判断,一种通过数组索引判断。

索引的方式:

 public class BaseSearch {

     private static int searchMode02(int[] arr, int mum) {
int index=-1;
for (int i = 0; i < arr.length; i++) {
if (arr[i]==mum) {
//在数组中
index=i;
break;
}
}
//不在数组中
return index;
} public static void main(String[] args) {
int[] arr = new int[] {1,2,3,4,5,6,7,8};
int result=searchMode02(arr, 10);
System.out.println(result !=-1 ? "元素在数组中":"元素不在数组中");
//元素不在数组中
} }

索引值判断的方式:

public class BaseSearch {

    private static boolean searchMode01(int[] arr, int mum) {
for (int i = 0; i < arr.length; i++) {
if (arr[i]==mum) {
//在数组中
return true;
}
}
//不在数组中
return false;
} public static void main(String[] args) {
int[] arr = new int[] {1,2,3,4,5,6,7,8};
System.out.println(searchMode01(arr, 10));
//结果false
} }

二分折半查找:

步骤:
1、定义最小索引和最大索引
2、计算中间索引
3、拿中间索引对应的数值和需要查找的数进行比较
  数值= 查找的数 返回中间索引
  数值 > 查找的数 在左边找
  数值 查找的数 在右边找
4、重复第二部
5、如果最小的数的值比最大值还要大,那么说明没有找到返回-1
6、二分查找的数组或者集合必须是有序的

 /**
*
* @author liqh
* @version 创建时间:2019年4月16日 上午9:12:56
* @ClassName 类名称
* @Description 二分查找实现 public class binarySearch {
/**
* @Title: main
* @Description:二分查找数组中的元素
* @param
* @return void 返回类型
* @throws
*/
public static int findArrValue(int[] arr,int mum) {
//定义数组最小元素索引
int min=0;
//定义数组最大元素索引
int max=arr.length-1;
//定义数组中间元素索引
int mid = (min+max)/2;
//判断中间值是否等于输入的数
while (arr[mid]!=mum) {
//判断中间索引值是否小于mum
if (arr[mid]<mum) {
//mum比中间值大,在右边,所以最小索引min需要中间值mid+1
min=mid+1;
}else if(arr[mid]>mum) {
//mum比中间值小,在左边,所以最大索引值max需要中间索引值mid+1
max=mid-1;
}
//如果一直递增的最小索引大于一直递减的最大缩影,那么就是没有找到
if (min>max) {
return -1;
}
//每次计算完之后,min和max都发生改变,中间索引值需要重新计算
mid = (min+max)/2; }
return mid; } public static void main(String[] args) {
int[] arr = new int[] {11,22,33,44,55,66,77,88};
//返回0,表示在数组中,-1表示不再数组中
System.out.println(findArrValue(arr, 11));
//结果 0 在数组中
} }

如果写的有什么问题,欢迎在下方评论指出来!

java数组集合元素的查找的更多相关文章

  1. Java依据集合元素的属性,集合相减

    两种方法:1.集合相减可以使用阿帕奇的一个ListUtils.subtract(list1,list2)方法,这种方法实现必须重写集合中对象的属性的hashCode和equals方法,集合相减判断的会 ...

  2. JAVA:数组,排序,查找<4>

    一.数组 1.一维数组 (1).数组的定义 数据类型 数组名[]=new 数据类型[大小] public class Demo1 { public static void main(String[] ...

  3. java数组集合

    一.ArrayList 1. ArrayList底层采用数组实现,当使用不带参数的构造方法生成ArrayList对象时,实际上会在底层生成一个长度为10的Object类型数组2. 如果增加的元素个数超 ...

  4. java list集合元素根据某些字段排序

    一.jdk1.6的环境下 新建ComparatorSort类,并实现Comparator接口,重写compare方法 降序排序:o1的元素>o2的元素,并返回-1:o1的元素小于o2的元素,并返 ...

  5. java 判断集合元素唯一的原理

    一 ArrayList的contains方法判断元素是否重复原理 ArrayList的contains方法会使用调用方法时,传入的元素的equals方法依次与集合中的旧元素 所比较,从而根据返回的布尔 ...

  6. java 数组插入元素

    import java.util.Arrays; public class AddArray { public static void main(String[] args) { int[] arr ...

  7. 面试题-Java基础-集合和数组

    1.Java集合类框架的基本接口有哪些? 集合类接口指定了一组叫做元素的对象.集合类接口的每一种具体的实现类都可以选择以它自己的方式对元素进行保存和排序.有的集合类允许重复的键,有些不允许.Java集 ...

  8. Java-杂项:Java数组Array和集合List、Set、Map

    ylbtech-Java-杂项:Java数组Array和集合List.Set.Map 1.返回顶部 1. 之前一直分不清楚java中的array,list.同时对set,map,list的用法彻底迷糊 ...

  9. java 数据类型:集合接口Collection之常用ArrayList;lambda表达式遍历;iterator遍历;forEachRemaining遍历;增强for遍历;removeIf批量操作集合元素(Predicate);

    java.util.Collection接口 Java的集合主要由两个接口派生出来,一个是Collection一个是Map,本章只记录Collection常用集合 集合只能存储引用类型数据,不能存储基 ...

随机推荐

  1. Reward List 赏金列表

    博主昨晚正在刷题,突然手机语音大声提示“微信支付收款到账”,把博主吓了一跳,打开一看,居然收到了第一笔打赏,还是博主最喜欢的数字,老开心了-感谢网友对于博主工作的认可与支持,多谢多谢!不管大家是物质打 ...

  2. 第一次c++作业小结

    之前从未接触过c++,上完第一节课后也还是懵懵懂懂.当知道有作业要完成时,也是无从下手.在仔细阅读教材以及同学的帮助下,我了解了如何编写最简单的程序,也算是踏入c++的大门.希望自己的第一次作业能够符 ...

  3. spring boot application.properties 属性详解

    2019年3月21日17:09:59 英文原版: https://docs.spring.io/spring-boot/docs/current/reference/html/common-appli ...

  4. Java中如何使用非强制类型转换把字符串转换成int类型

    ①强制类型转换代码如下: String string = "123456"; int a,b = 0; @Test public void String2Int1() { //方法 ...

  5. oracle连表语法

    1.笛卡尔积 (表一乘以表二) (表连接建立在笛卡尔积上过滤) select * from emp,dept; 2.等值连接 (表与表之见有相同的列表) select ename,dname from ...

  6. SSZipArchive解压乱码

    https://www.twblogs.net/a/5b7e01e22b7177683854b7b8/zh-cn 搜索   CFStringConvertEncodingToNSStringEncod ...

  7. 关于Java项目打包成Runnable jar文件后运行时图片不显示的问题

    现象:在eclipse中能够无误运行,但导出Runnable jar后运行jar包时不显示图片. 原因:路径问题. 方法1: 新建一个文件夹.文件夹中放那个jar包和image文件夹.在这种情况下,双 ...

  8. JavaScript 中 return,return true,return false

    1.return: ①return + 表达式,调用函数,并返回表达式的值 ②return,终止函数 ③当代码执行到return语句时,函数返回一个结果就结束运行了,return后面的语句根本不会执行 ...

  9. ORACLE——获取随机数

    在oracle中获取一个指定的随机数: --(DBMS_RANDOM.VALUE(INT NUM1,INT NUM2),比如: ,) FROM DUAL; --结果:8.23602331029803 ...

  10. GIT回滚master分支到指定tag版本

    master版本上线以后一般要打一个tag备份,以防事态有变,这是一个好习惯,如果以后有问题也可以放心的回滚版本,那么怎么用tag版本覆盖mastaer呢,其实只有几个命令 1.查看分支 git br ...