二分法的代码java,java版本的二分法算法实现

class ErFenFa

{

int[] iArray={1,5,9,14,27,39,41,50,62,222,345,612,981,1207,8721}; //在此数字序列中寻找

int iSeek=345; //寻找345的位置

int iCount=0; //比较的次数

http://www.gaodaima.com/41362.htmljava版本的二分法算法实现

public int xunhuan()

//普通的循环法,最少需要比较一次,比如查找1,最多需要比较15次,比如8721

{

for(int i=0;i

{

iCount++;

if (iSeek==iArray[i])

break;

}

return iCount;

}

public int erfen()

//二分法查找

{

int iIndex=0; //相当于指针的东西

int iStart=0; //

int iEnd=iArray.length-1;

while(true)

{

iCount++;

iIndex = (iStart+iEnd)/2;

if(iArray[iIndex]

{

iStart = iIndex;

}

else if(iArray[iIndex]>iSeek)

{

iEnd = iIndex;

}

else

{

break;

}

}

return iCount;

}

public static void main(String[] args)

{

ErFenFa eff=new ErFenFa();

ErFenFa eff1=new ErFenFa();

System.out.println("普通的循环查找,需要比较的次数:"+eff.xunhuan());

System.out.println("二分法查找,需要比较的次数:"+eff1.erfen());

}

}

欢迎大家阅读《java版本的二分法算法实现》,跪求各位点评,若觉得好的话请收藏本文,by 搞代码

原创文章,转载请注明: 转载自搞代码

e7ce419cf2d6ad34d01da2ceb8829eed.png

微信 赏一包辣条吧~

023a57327877fb4402bcc76911ec18ea.png

支付宝 赏一听可乐吧~

  • 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、付费专栏及课程。

余额充值