java二分检索算法代码 实现二分查找的递归算法java

急求java冒泡排序 快速排序 二分之一查找的代码//标记法
public class Test {
public static void main(String[] args){
int[] array = {9,7,5,8,7,5,3,8,4,2,6,1,0};
for(int i = 0; iarray.length; i){
int temp = i;
for(int j=i 1; jarray.length; j){
if(array[temp]array[j]){
temp=j;
}
}
int buff = array[temp];
array[temp] = array[i];
array[i] = buff;
}
for(int a : array){
System.out.println(a);
}
}
}
//二分之一
public class Test {
public void find(int x){
int[] s = {1,2,3,6,7,8,9,12,13,14,15,16,17,18,19,20,23,25,27,30,32,40,50};
int start = 0;
int end = s.length;
int half = end/2;
while(true){
if(s[half]x){
start = half;
half = half(end-start)/2;
}else if(s[half]x){
end = half;
half = half - (end-start)/2;
}else{
System.out.println(half 1);
break;
}
}
}
public static void main(String[] args){
new Test().find(20);
}
}
什么叫java中的二分查找法1、算法概念 。
二分查找算法也称为折半搜索、二分搜索,是一种在有序数组中查找某一特定元素的搜索算法 。请注意这种算法是建立在有序数组基础上的 。
2、算法思想 。
①搜素过程从数组的中间元素开始,如果中间元素正好是要查找的元素,则搜素过程结束;
②如果某一特定元素大于或者小于中间元素 , 则在数组大于或小于中间元素的那一半中查找,而且跟开始一样从中间元素开始比较 。
③如果在某一步骤数组为空 , 则代表找不到 。
这种搜索算法每一次比较都使搜索范围缩小一半 。
3、实现思路 。
①找出位于数组中间的值,并存放在一个变量中(为了下面的说明 , 变量暂时命名为temp);
②需要找到的key和temp进行比较;
③如果key值大于temp,则把数组中间位置作为下一次计算的起点;重复① ② 。
④如果key值小于temp,则把数组中间位置作为下一次计算的终点;重复① ② ③ 。
⑤如果key值等于temp,则返回数组下标,完成查找 。
4、实现代码 。
/**
* description : 二分查找 。
* @param array 需要查找的有序数组
* @param from 起始下标
* @param to 终止下标
* @param key 需要查找的关键字
* @return
*/
public static E extends ComparableE int binarySearch(E[] array, int from, int to, E key) throws Exception {
if (from0 || to0) {
throw new IllegalArgumentException("params fromlength must larger than 0 .");
}
if (from = to) {
int middle = (from1)(to1); // 右移即除2
E temp = array[middle];
if (temp.compareTo(key)0) {
to = middle - 1;
} else if (temp.compareTo(key)0) {
from = middle1;
} else {
return middle;
}
}
return binarySearch(array, from, to, key);
}
java泛型 二分查找以下代码是关于对象的 二分查找 的例子,已经测试通过,执行即可 。
Student 是基本比较对象类
Dichotomy 是二分法执行类
Test 是测试类
package com.dichotomy;
public class Student implements ComparableStudent {
private int id;
private String name;
private String idCard;
private String sex;
private String mobile;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getIdCard() {
return idCard;
}
public void setIdCard(String idCard) {
this.idCard = idCard;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}
public String getMobile() {
return mobile;
}
public void setMobile(String mobile) {
this.mobile = mobile;
}
/**
* 排序控制
* @param o1 Student
* @param o2 Student
* @return int 返回 -1 向前移动, 1 向后移动, 0 不移动
* 这个方法需要自己进行调整 , 排序比较和二分查找时均使用此方法进行位置调整
* 比较时使用的key自己可以进行修改 , 不过要保证唯一性 , 否则查询出来的值会不准确
*/
public int compareTo(Student o) {
//不同的执行次序决定排序和查找次序不同,可以同下面的调换一下
if(this.getId()o.getId()){
return -1;
} else if(this.getId() == o.getId()){
;
} else {
return 1;
}
//不同的执行次序决定排序和查找次序不同
int c = this.getIdCard().compareTo(o.getIdCard());
if(c != 0){
return c;
}
//不同的执行次序决定排序和查找次序不同
int n = this.getName().compareTo(o.getName());
if(n != 0){
return n;
【java二分检索算法代码 实现二分查找的递归算法java】}
return 0;
}
public String toString(){
StringBuffer sb = new StringBuffer();
sb.append(this.getId()).append("\t");
sb.append(this.getName()).append("\t");
sb.append(this.getIdCard()).append("\t");
sb.append(this.getMobile()).append("\t");
sb.append(this.getSex());
return sb.toString();
}
}
java二分搜索算法怎样实现?应该要用递归方法吧java二分检索算法代码? binarySearch()方法应该要带四个参数(数组java二分检索算法代码,要查找java二分检索算法代码的数值,查找范围java二分检索算法代码的最左边下标,查找范围的最右边下标) 。然后就利用递归方法在if (xa[middle])和else后面通过修改查找范围自调用binarySearch()方法java二分检索算法代码;
java二分法查找的递归算法怎么实现什么是二分查找?
二分查找也称折半查找(Binary Search),它是一种效率较高的查找方法 。但是,折半查找要求线性表必须采用顺序存储结构,而且表中元素按关键字有序排列 。
二分查找优缺点
优点是比较次数少 , 查找速度快,平均性能好;
其缺点是要求待查表为有序表 , 且插入删除困难 。
因此,折半查找方法适用于不经常变动而查找频繁的有序列表 。
使用条件:查找序列是顺序结构,有序 。
过程
首先,假设表中元素是按升序排列,将表中间位置记录的关键字与查找关键字比较,如果两者相等,则查找成功;否则利用中间位置记录将表分成前、后两个子表,如果中间位置记录的关键字大于查找关键字,则进一步查找前一子表,否则进一步查找后一子表 。重复以上过程,直到找到满足条件的记录,使查找成功,或直到子表不存在为止,此时查找不成功 。
利用循环的方式实现二分法查找
public class BinarySearch {
public static void main(String[] args) {
// 生成一个随机数组int[] array = suiji();
// 对随机数组排序Arrays.sort(array);
System.out.println("产生的随机数组为: "Arrays.toString(array));
System.out.println("要进行查找的值: ");
Scanner input = new Scanner(System.in);
// 进行查找的目标值int aim = input.nextInt();
// 使用二分法查找int index = binarySearch(array, aim);
System.out.println("查找的值的索引位置: "index);
}
/*** 生成一个随机数组*
* @return 返回值,返回一个随机数组*/
private static int[] suiji() {
// random.nextInt(n) m返回m到m n-1之间的随机数int n = new Random().nextInt(6)5;
int[] array = new int[n];
// 循环遍历为数组赋值for (int i = 0; iarray.length; i) {
array[i] = new Random().nextInt(100);
}
return array;
}
/*** 二分法查找---循环的方式实现*
* @param array 要查找的数组* @param aim 要查找的值* @return 返回值,成功返回索引,失败返回-1*/
private static int binarySearch(int[] array, int aim) {
// 数组最小索引值int left = 0;
// 数组最大索引值int right = array.length - 1;
int mid;
while (left = right) {
mid = (leftright) / 2;
// 若查找数值比中间值?。?则以整个查找范围的前半部分作为新的查找范围if (aimarray[mid]) {
right = mid - 1;
// 若查找数值比中间值大 , 则以整个查找范围的后半部分作为新的查找范围} else if (aimarray[mid]) {
left = mid1;
// 若查找数据与中间元素值正好相等,则放回中间元素值的索引} else {
return mid;
}
}
return -1;
}}
运行结果演示:
由以上运行结果我们得知,如果要查找的数据在数组中存在,则输出该数据在数组中的索引;如果不存在则输出 -1 ,也就是打印 -1 则该数在数组中不存在,反之则存在 。
四、利用递归的方式实现二分法查找
public class BinarySearch2 {
public static void main(String[] args) {
// 生成一个随机数组int[] array = suiji();
// 对随机数组排序Arrays.sort(array);
System.out.println("产生的随机数组为: "Arrays.toString(array));
System.out.println("要进行查找的值: ");
Scanner input = new Scanner(System.in);
// 进行查找的目标值int aim = input.nextInt();
// 使用二分法查找int index = binarySearch(array, aim, 0, array.length - 1);
System.out.println("查找的值的索引位置: "index);
}
/*** 生成一个随机数组** @return 返回值,返回一个随机数组*/
private static int[] suiji() {
// Random.nextInt(n) m返回m到m n-1之间的随机数int n = new Random().nextInt(6)5;
int[] array = new int[n];
// 循环遍历为数组赋值for (int i = 0; iarray.length; i) {
array[i] = new Random().nextInt(100);
}
return array;
}
/*** 二分法查找 ---递归的方式** @param array 要查找的数组* @param aim要查找的值* @param left左边最小值* @param right 右边最大值* @return 返回值 , 成功返回索引,失败返回-1*/
private static int binarySearch(int[] array, int aim, int left, int right) {
if (aimarray[left] || aimarray[right]) {
return -1;
}
// 找中间值int mid = (leftright) / 2;
if (array[mid] == aim) {
return mid;
} else if (array[mid]aim) {
//如果中间值大于要找的值则从左边一半继续递归return binarySearch(array, aim, left, mid - 1);
} else {
//如果中间值小于要找的值则从右边一半继续递归return binarySearch(array, aim, mid1, array.length-1);
}
}}
运行结果演示:
总结:
递归相较于循环,代码比较简洁,但是时间和空间消耗比较大 , 效率低 。在实际的学习与工作中,根据情况选择使用 。通常我们如果使用循环实现代码只要不是太繁琐都选择循环的方式实现~
java二分检索算法代码的介绍就聊到这里吧,感谢你花时间阅读本站内容 , 更多关于实现二分查找的递归算法java、java二分检索算法代码的信息别忘了在本站进行查找喔 。

    推荐阅读