`
xiaoming123123
  • 浏览: 98807 次
  • 性别: Icon_minigender_1
  • 来自: 南昌
社区版块
存档分类
最新评论

从数组中查找任何一个数字所在的位置(索引)

    博客分类:
  • J2SE
阅读更多
方式一:
/*
 * 从数组中查找9是在哪个位置,使用这种方式效率比较低
 */
package com.array;

public class ArraySearchTest {

	public static int search(int[] array, int value) {
		
		for(int i = 0; i < array.length; i++) {
			
			if(value == array[i]) {   //判断9是否与数组的索引相等
				return i;           //返回索引
			}
		}
		
		return -1;
	}
	
	public static void main(String[] args) {
		
		int[] a = new int[]{1,5,6,7,10,3,9};
		
		int value = 9;
		
		int index = search(a,value);
		
		System.out.println(index);
	}

}


总结:通过上面的查找方式发现,效率比较低,当数组元素是几千几万个的时候,要进行一个一个的比较,这种方式是非常低的;这种方式只适合,数组元素比较少的情况下,才适合

方式二:使用二分查找 高效查找数组元素的索引

二分查找法实现原理:
(1) 必须是有序的
(2) 将一组元素,一分为二

对1,3,5,6,7,8,10,12,15,16,19,22,23,25,27查找出25这个元素

分析:(1)这一组元素它总共是15个元素,一分为二之后,左边7个(1,3,5,6,7,8,10,),右边7个(15,16,19,22,23,25,27),中间就是第8个元素所对应的数字是12,因为12<25,所以把12之前的数字包括12本身全都过滤掉
(2)因为已经把12之前的数字包括12本身都过滤掉了,所以剩下15,16,19,22,23,25,27这7个元素,又把7一分为二,左边3个(15,16,19),右边3个(23,25,27),中间只剩下22,把22与25比较,因为22<25,所以把22之前的数字包括22本身过滤掉
(3) 最后只剩下23,25,27这三个元素,再一分为二,取中间元素25,就是我们要找的数字
请看下面代码:
package com.array;

public class ArraySearchTest1 {

	public static int binarySearch(int[] array,int value) {
		
		int low = 0;                   //low为数组下标的第一个元素
		int high = array.length - 1;  //high为数组下标最后一个元素
		int middle;                  //定义中间元素
		
		while(low <= high) {
			
			middle = (low + high) /2;    //取第一次中间的元素
			
			if(array[middle] == value) {
				return middle;
			}
			
			if(value < array[middle]) {
				high = middle - 1;
			}
			
			if(value > array[middle]) {
				low = middle + 1;
			}
		}
		
		return -1;
	}
	
	public static void main(String[] args) {

		int[] a = new int[]{1,3,5,6,7,8,10,12,15,16,19,22,23,25,27};
		
		int value = 25;
		
		int index = binarySearch(a,value);
		
		System.out.println(index);
	}

}

分享到:
评论
1 楼 q694119254 2012-08-07  
你个2人  数组没排序怎么办

相关推荐

    《javaScrip开发技术大全》源代码

    • sample25.htm 统计一个字符串在另一个字符串中出现的次数 • sample26.htm 使用正则表达式搜索子字符串 • sample27.htm 替换使用字符串查找到的子字符串 • sample28.htm 扩展...

    PHP开发实战1200例源码

    实例128 获取数组中最后一个元素 158 实例129 去除数组中的重复元素 158 实例130 字符串与数组的转换 159 实例131 对数组元素进行随机排序 160 实例132 随机抽取数组中元素 161 实例133 二维数组的输出 162 实例134 ...

    《C#经典编程220例》.(明日科技).【带书签】-共3部分

    实例046 在数组中添加一个数组 73 实例047 计算两个矩形矩阵的乘积 75 实例048 获取多维数组的行数与列数 78 实例049 使用快速排序法对一维数组进行排序 79 实例050 使用sort方法对数组进行快速排序 81 实例051 按...

    超级有影响力霸气的Java面试题大全文档

    对象的一个新类可以从现有的类中派生,这个过程称为类继承。新类继承了原始类的特性,新类称为原始类的派生类(子类),而原始类称为新类的基类(父类)。派生类可以从它的基类那里继承方法和实例变量,并且类可以...

    明日科技C#开发入门及项目实战

    实例046 在数组中添加一个数组 实例047 计算两个矩形矩阵的乘积 实例048 获取多维数组的行数与列数 实例049 使用快速排序法对一维数组进行排序 实例050 使用sort方法对数组进行快速排序 实例051 按指定条件在数组中...

    java 面试题 总结

    对象的一个新类可以从现有的类中派生,这个过程称为类继承。新类继承了原始类的特性,新类称为原始类的派生类(子类),而原始类称为新类的基类(父类)。派生类可以从它的基类那里继承方法和实例变量,并且类可以...

    PHP开发实战1200例(第1卷).(清华出版.潘凯华.刘中华).part1

    实例128 获取数组中最后一个元素 158 实例129 去除数组中的重复元素 158 实例130 字符串与数组的转换 159 实例131 对数组元素进行随机排序 160 实例132 随机抽取数组中元素 161 实例133 二维数组的输出 162 实例134 ...

    PHP开发实战1200例(第1卷).(清华出版.潘凯华.刘中华).part2

    实例128 获取数组中最后一个元素 158 实例129 去除数组中的重复元素 158 实例130 字符串与数组的转换 159 实例131 对数组元素进行随机排序 160 实例132 随机抽取数组中元素 161 实例133 二维数组的输出 162 实例134 ...

    oracle学习文档 笔记 全面 深刻 详细 通俗易懂 doc word格式 清晰 连接字符串

    说明:Oracle中要删除一个用户,必须要具有dba的权限。而且不能删除当前用户,如果删除的用户有数据对象,那么必须加上关键字cascade。 用法:drop user 用户名 [cascade] 四、 用户权限与角色 1. 权限 Oracle中权限...

    易语言程序免安装版下载

     静态编译后的易语言EXE/DLL之间不能再共享譬如窗口、窗口组件等类似资源,对于已经静态连接到一个EXE/DLL中的支持库,该支持库中的数据或资源将不能再被其它EXE/DLL中所使用的同名支持库访问。这是因为代码被分别...

    freemarker总结

    上面的语法格式中,sequence就是一个集合对象,也可以是一个表达式,但该表达式将返回一个集合对象,而item是一个任意的名字,就是被迭代输出的集合元素.此外,迭代集合对象时,还包含两个特殊的循环变量: item_index:...

    PHP程序开发范例宝典III

    实例047 同一个页面中的多表单提交 66 实例048 获取表单中提交的所有数据 68 实例049 以文件域的形式显示数据信息 70 第3章 CSS与JavaScript脚本的应用 73 3.1 文字特效 74 实例050 逐个闪烁的文字 74 ...

    VBA常用技巧

    技巧3 获得指定行、列中的最后一个非空单元格 12 技巧4 定位单元格 12 技巧5 查找单元格 12 5-1 使用Find方法 12 5-2 使用Like运算符 12 技巧6 替换单元格内字符串 12 技巧7 复制单元格区域 12 技巧8 仅复制数值到另...

    VBA编程技巧大全

    技巧3 获得指定行、列中的最后一个非空单元格 17 技巧4 定位单元格 20 技巧5 查找单元格 21 5-1 使用Find方法 21 5-2 使用Like运算符 25 技巧6 替换单元格内字符串 26 技巧7 复制单元格区域 27 技巧8 仅复制数值到另...

    C#程序开发范例宝典(第2版).part02

    精选570个典型范例,全面覆盖实用和热点技术,涉及面广,实用性强源于实际项目开发,帮助读者短时间掌握更多实用技术,提高编程水平范例经过精心编排,重点、难点突出,易学易懂书后附录提供快速索引,即查、即学、...

    C#程序开发范例宝典(第2版).part08

    精选570个典型范例,全面覆盖实用和热点技术,涉及面广,实用性强源于实际项目开发,帮助读者短时间掌握更多实用技术,提高编程水平范例经过精心编排,重点、难点突出,易学易懂书后附录提供快速索引,即查、即学、...

    C#程序开发范例宝典(第2版).part13

    精选570个典型范例,全面覆盖实用和热点技术,涉及面广,实用性强源于实际项目开发,帮助读者短时间掌握更多实用技术,提高编程水平范例经过精心编排,重点、难点突出,易学易懂书后附录提供快速索引,即查、即学、...

    C#程序开发范例宝典(第2版).part12

    精选570个典型范例,全面覆盖实用和热点技术,涉及面广,实用性强源于实际项目开发,帮助读者短时间掌握更多实用技术,提高编程水平范例经过精心编排,重点、难点突出,易学易懂书后附录提供快速索引,即查、即学、...

Global site tag (gtag.js) - Google Analytics