折半查找

感谢  

帮我优化


 

package 方法集合;

import java.util.Random;

public class testMe {

 static Random Rd = new Random();


 public static void main(String[] args) {
  int[] arr = new int[11];
  for (int i = 0; i < arr.length; i++) {
   arr[i] = Rd.nextInt() >>> 28;
  }
  new ArrSort().arrSort(arr);
  for (int i = 0; i < arr.length; i++) {
   System.out.print(arr[i] + " ");
  }
  boolean contains = new Find().arrFindNum(10, arr);
  System.out.println(contains);
 }
}


class Find {

 /**
  * 查找有序数组中是否有某个数
  *
  * @param a
  *            查找的数
  * @param arr
  *            数组
  * @return true: 有 false: 没有
  */
 public boolean arrFindNum(int a, int arr[]) {
  int head = 0;
  int tail = arr.length;
  int index = (tail - head) / 2;
  while (true) {
   if (a == arr[index]) {
    return true;
   }
   if (a > arr[index]) {
    head = index;
   } else {
    tail = index;
   }
   index = (tail + head) / 2;
   if (index == head) {
    return false;
   }
  }
 }
}


class ArrSort {

 public void arrSort(int[] arr) {
  for (int i = 0; i < arr.length; i++) {
   for (int j = 0; j < arr.length - i - 1; j++) {
    if (arr[j] > arr[j + 1]) {
     int tmp = arr[j];
     arr[j] = arr[j + 1];
     arr[j + 1] = tmp;
    }
   }
  }
 }
}

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值