二分法java算法,Java二分法

Java二分法

贴段代码,有少许注释:

package ibees;

import java.util.Arrays;

public class BinarySearch {

/**

* @param args

*/

public static void main(String[] args) {

double[] src = new double[]{1.3,9.9,10.89,12.89,89.0};

System.out.println(new BinarySearch().binarySearch(src, 89.0));

}

/**

* 二分法查找

* */

public int binarySearch(double[] src, double des){

Arrays.sort(src);

int beginIndex = 0;

int endIndex = src.length-1;

int middle = (endIndex+beginIndex)/2;

while(src[middle] != des && beginIndex != endIndex){

//最后两项

if(beginIndex+1 == endIndex){

if(src[beginIndex] == des){

return beginIndex;

}else if(src[endIndex] == des){

return endIndex;

}else{

return -1;

}

}

//判断中间的数与给定数之间的关系

if(des > src[middle]){

beginIndex = middle+1;

}else if(des < src[middle]){

endIndex = middle-1;

}else{

return middle;

}

middle = (endIndex + beginIndex)/2;

}

return middle;

}

}

想想返回的数组索引是不对的。

相关文档:

原题如下:用1、2、2、3、4、5这六个数字,用java写一个程序,打印出所有不同的排列,如:512234、412345等,要求:"4"不能在第三位,"3"与"5"不能相连。

解题思路:

很明显,这是一个递归算法。我们可以排列将这6个数按从小到大的顺序排一下,如果是1,2,3,4,5,6,那么会有1 ......

java 集合框架(Collection)和数组的排序

根据约定,在使用java编程的时候应尽可能的使用现有的类库,当然你也可以自己编写一个排序的方法,或者框架,但是有几个人能写得比JDK里的还要好呢?使用现有的类的另一个好处是代码易于阅读和维护,这篇文章主要讲的是如何使用现有的类库对数组和各种Collection容器进 ......

反射的概念是由Smith在1982年首次提出的,主要是指程序可以访问、检测和修改它本身状态或行为的一种能力。这一概念的提出很快引发了计算机科学领域关于应用反射性的研究。它首先被程序语言的设计领域所采用,并在Lisp和面向对象方面取得了成绩。其中LEAD/LEAD++ 、OpenC++ 、MetaXa和OpenJava等就是基于反射机制的语言。最近 ......

1.   验证码(2)

dsnaValidateCode.jar

dsnaValidateCode_src.rar

ValidateCode.java 验证码生成类

Java代码

package cn.dsna.util.images;

import java.awt.Color;

import java.awt.Font;

import java.awt.Graphics2D; &nbsp ......

工作中遇到需要合并XML的问题,遂从网上查找相关资料,

1、 《 XML merging made easy

2 、《java中合并xml文档的设计与实现

测试后发现均不符合实际需求,实际需求如下:

file1.xml:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
二分法(二分查找)是一种在有序数组中查找某一特定元素的搜索算法。实现的基本思路是将数组从中间开始分成两部分,判断要查找的元素在哪一部分中,然后继续在该部分中进行查找,直到找到目标元素或者确定目标元素不存在为止。 下面是用 Java 实现二分法算法的示例代码: ```java public class BinarySearch { // 二分法查找指定元素在数组中的位置 public static int binarySearch(int[] arr, int target) { int left = 0; int right = arr.length - 1; while (left <= right) { int mid = (left + right) / 2; if (arr[mid] == target) { return mid; } else if (arr[mid] < target) { left = mid + 1; } else { right = mid - 1; } } return -1; } // 测试二分法算法 public static void main(String[] args) { int[] arr = {1, 2, 3, 4, 5, 6, 7, 8, 9}; int target = 5; int result = binarySearch(arr, target); if (result == -1) { System.out.println("元素不在数组中"); } else { System.out.println("元素在数组中的位置为:" + result); } } } ``` 在这个示例代码中,我们定义了一个 `binarySearch` 方法来实现二分法算法。该方法接收两个参数:一个有序数组和一个目标元素。在方法中,我们定义了两个变量 `left` 和 `right` 分别表示数组的左右边界。然后使用一个 while 循环来不断缩小查找范围,直到找到目标元素或者确定目标元素不存在为止。 在循环中,我们首先计算出数组的中间位置 `mid`,然后判断目标元素是在中间位置的左边还是右边。如果目标元素比中间位置的值要大,则说明目标元素在中间位置的右边,需要将左边界向右移动;反之,如果目标元素比中间位置的值要小,则说明目标元素在中间位置的左边,需要将右边界向左移动。当左边界大于右边界时,表示目标元素不存在于数组中,此时返回 -1。 最后,我们在 `main` 方法中调用 `binarySearch` 方法来测试二分法算法。在测试中,我们定义了一个有序数组和一个目标元素,并将它们作为参数传递给 `binarySearch` 方法。如果方法返回的结果为 -1,则表示目标元素不在数组中;否则,方法返回的结果就是目标元素在数组中的位置。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值