A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

一、二分法查找
1.二分法查找是建立在已经排序的基础之上的
2.程序分析是从下到大​排序。
3.这个数组中没有重复的元素​。
[url=][/url]
package com.bjpowernode.java_learning;​public class D71_1_ {  public static void main(String[] args) {    int[] a1 = {1,5,8,9,11,25,45,55};    int destElement = 29;    int index = binarySearch(a1,destElement);​    System.out.println((index==-1)?destElement + "元素不存在!":destElement + "在数组中的下标是:" + index);  }   public static int binarySearch(int[] a2 ,int destElement) {    int begin = 0;    int end = a2.length-1;​       while (begin<=end) {      int mid = (begin+end)/2;           if(a2[mid] == destElement) {        return mid;      }else if(a2[mid] >destElement) {        end = mid -1;      }else {        begin = mid +1;      }    }    return -1;  }}[url=][/url]

二、Arrays工具类
Arrays是SUN公司提供的一个工具类
java.utils.Arrays;
该工具类主要针对的是数组的操作​,例如:排序、二分查找​。对应函数为Arrays.sort;Arrays.binarySearch;

[url=][/url]
package com.bjpowernode.java_learning;import java.util.Arrays;public class D71_2_ArraysToolsClass {  public static void main(String[] args) {    int [] a1 = {45,7,5,9,21,25,98};    Arrays.sort(a1);    for (int i= 0;i<a1.length;i++) {      System.out.println(a1);    }    System.out.println("==================");    int index = Arrays.binarySearch(a1,98);    System.out.println(index);        }}[url=][/url]


1 个回复

倒序浏览
有任何问题欢迎添加学姐微信
DKA-2018
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马