二分法的Java实现

二分法查找主要针对的是有序的数组,每一次查找与中间值比较,可以确定是否查找成功,不成功当前查找区间缩小一半。

    public class TestSearch{
        public static void main(String[] args){
            int[] a= {1, 3, 6, 8, 9, 10, 12, 18, 20, 34 };
            int i=12;
            //System.out.println(search(a,i));
            System.out.println(binarySearch(a,i));
            }
        public static int search(int[] a,int num){
            for(int i=0;i<a.length;i++){
                if(a[i]==num){
                    return i;
                    }
                }
            return -1;
            }
        public static int binarySearch(int[] a,int num){
            if(a.length==0) return -1;
            int startPos=0;
            int endPos=(a.length)-1;
            int m=(startPos+endPos)/2;
            while(a[startPos]<=a[endPos]){
                if(num==a[m]) return m;
                if(num<a[m]){
                    endPos=m-1;
                    }
                if(num>a[m]){
                    startPos=m+1;
                    }
                m=(startPos+endPos)/2;
                }
            return -1;
            }
        }
时间: 2024-09-06 22:21:40

二分法的Java实现的相关文章

二分法查找——Java

首先介绍一下什么是二分法查找. 顾名思义二分法即多次将待查数组的长度折半,但前提条件时待查找数组中的数据需要是已经排序好了的数据. 主要思想: 对于待查找数组arr[low,high],其中high=arr.length-1,待查找元素des (1)确定数组中间位置mid=(low+high)/2 (2)将查找值des与arr[mid]进行比较,若相等,则直接返回该位置:否则确定新的查找位置,继续二分查找.区域确定如下:如果arr[mid]>des由数组的有序性可知 arr[mid,mid+1.

java的二分法查找数据

Java二分法查找的源代码:    二分查找是一种高效率线性表的查找算法.在查找时必须将线性表中的关键词排好序.基本思路是:先断定线性表的中心方位 mid=(first+last)/2:对比所要查找的关键词 key与中心方位的关键词的巨细,假如比key和mid.key持平则回来: key比mid.key大(假定为升序)这所要查找的关键词在mid和last之间:否则在first与mid之间.持续按照上面办法查找中心元素,直到找到为止.    详细完成如下package com.cgogo; /**

Java实现折半查找(二分法)

利用Java实现折半查找 基本思路:while递归循环,不断判断a[middle]是否等于data,如果等于则跳出循环,返回索引值,如果不等,则进行二分处理,直至两者相等为止:其中通过count计数器记录查找次数,当count次数超过20次时视为元素不存在(此处有待优化) package test; /* * 二分法查找(折半查找) * TGmoving * */ public class halfSearch { public static int HalfSearch(int a[],int

Java排序查找算法——二分法与递归的应用实例

问题描述: 对数组元素进行查找与排序,利用二分法与递归实现. 完整实例1: public class SortDemo {    public static void main(String[] args)    {       int[] arr={10,2,300,41,15,6};       for(int a:arr)       {          System.out.print("["+a+"]");           }      // new

Java递归实现二分法,希望各位指点一下

/* 3.使用二分法查找有序数组中元素.找到返回索引,不存在输出-1.使用递归实现   */   import java.util.Scanner;   public class Recursion{   public static void main(String[]args)   {   System.out.println("请输入要找的整数");   Scanner sc=new Scanner(System.in);   int num = sc.nextInt();   i

Java中的二分法查找算法

[ 什么是二分查找 ]  二分查找又称为折半查找,该算法的思想是将数列按序排列,采用跳跃式方法进行查找,即先以有序数列的中点位置为比较对象, 如果要找的元素值小于该中点元素,则将待查序列缩小为左半部分,否则为右半部分.以此类推不断缩小搜索范围. [ 二分查找的条件 ] 二分查找的先决条件是查找的数列必须是有序的. [ 二分查找的优缺点 ] 优点:比较次数少,查找速度快,平均性能好: 缺点:要求待查数列为有序,且插入删除困难: 适用场景:不经常变动而查找频繁的有序列表. [ 算法步骤描述 ] ①

java 实现二分法

http://www.cnblogs.com/vanezkw/archive/2012/06/29/2569470.html JDK里面的二分法实现.二分法的实现有多种今天就给大家分享两种.一种是递归方式的,一种是非递归方式的.先来看看一些基础的东西. 1.算法概念. 二分查找算法也称为折半搜索.二分搜索,是一种在有序数组中查找某一特定元素的搜索算法.请注意这种算法是建立在有序数组基础上的. 2.算法思想. ①搜素过程从数组的中间元素开始,如果中间元素正好是要查找的元素,则搜素过程结束: ②如果

Java常用排序算法+程序员必须掌握的8大排序算法+二分法查找法

Java 常用排序算法/程序员必须掌握的 8大排序算法 本文由网络资料整理转载而来,如有问题,欢迎指正! 分类: 1)插入排序(直接插入排序.希尔排序) 2)交换排序(冒泡排序.快速排序) 3)选择排序(直接选择排序.堆排序) 4)归并排序 5)分配排序(基数排序) 所需辅助空间最多:归并排序 所需辅助空间最少:堆排序 平均速度最快:快速排序 不稳定:快速排序,希尔排序,堆排序. 先来看看 8种排序之间的关系: 1.直接插入排序 (1)基本思想:在要排序的一组数中,假设前面(n-1)[n>=2]

JAVA学习笔记-二分法排序(增强for循环)

package MyErFenPaiXu; public class Mycode { public static void main(String[] args){ int[] a ={18,63,25,46,3,0,99,1,2}; for(int j=0;j<a.length-1;j++){ //这里的意思为不断的比较,次数只要不小于5次就能遍历出想要的结果. for(int i=0;i<a.length-1-j;i++){ //遍历一次,一个大数会被移到最后的位置. if(a[i]&g