折半查找法也称为二分查找法,它充分利用了元素间的次序关系,采用分治策略,可在最坏的情况下用O(log n)完成搜索任务。它的基本思想是,将n个元素分成个数大致相同的两半,取a[n/2]与欲查找的x作比较,如果x=a[n/2]则找到x,算法终止。如 果x<a[n/2],则我们只要在数组a的左半部继续搜索x(这里假设数组元素呈升序排列)。如果x>a[n/2],则我们只要在数组a的右 半部继续搜索x。

二分查找有个缺点就是元数据必须是有序的,因此二分查找之前必须对对数组排序,可以根据需要选择适当的排序算法这里选择的快速排序算法。

  • 首先设定三个变量,lownum,midnum,hignum 假定有十个元素则lownum = 0,hignum=9,midnum=(lownum+highnum)/2.key为查找数据。
  • 如果a[midnum] = key,表示查找到数据,返回midnum
  • 如果key<a[midnum]则midnum = midnum-1,递归查找a[0] ~ a[midnum-1]
  • 如果key>a[midnum]则midnum = midnum+1,递归查找a[midnum+1] ~a[highnum].

下面看一下java的代码实现

package neuq.chao;
import java.util.Scanner;
class QuickSort{
static void quickSort(int []a,int left,int right){
int ltemp,rtemp,base;
ltemp = left;
rtemp = right;
int t;
base = a[(right+left)/2]; //选取中间元素作为边界
while(ltemp<rtemp){
while(a[ltemp]<base){
++ltemp; //ltemp向右移
}
while(a[rtemp]>base){
--rtemp; //rtemp向左移
}
if(ltemp<=rtemp){
t = a[ltemp];
a[ltemp] = a[rtemp];
a[rtemp] = t;
++ltemp;
--rtemp;
}
}
if(ltemp==rtemp){
ltemp++;
}
if(left<rtemp){
quickSort(a,left,ltemp-1);
}
if(ltemp<right){
quickSort(a,rtemp+1,right);
}
}
} public class BinarySearch { //折半查找
static final int SIZE = 10;
static Scanner input = new Scanner(System.in);
static int binarySearch(int []a,int left,int right,int key){
int lownum,midnum,hignum;
lownum = left;
midnum = (left+right);
hignum = right;
int i =-1;
if(key==a[midnum]){
i = midnum;
}
if(key<a[midnum]){
i = binarySearch(a,lownum,midnum-1,key);
}
if(key>a[midnum]){
i = binarySearch(a,midnum+1,hignum,key);
}
return i;
}
public static void main(String args[]){
int shuzu[] = new int[SIZE];
int h,j,i,n;
for(h=0;h<SIZE;h++){
shuzu[h] = (int)(100+Math.random()*(100+1));
}
// QuickSort qs = new QuickSort();
QuickSort.quickSort(shuzu,0,SIZE-1);
System.out.print("数组的数据为: \n");
for(i=0;i<SIZE-1;i++){
System.out.print(shuzu[i]+" ");
}
System.out.print("\n");
System.out.print("请输入查找的数据: \n");
n = input.nextInt();
j = binarySearch(shuzu,0,SIZE-1,n);
if(j<0){
System.out.print("未查找到数据");
}
else{
System.out.print(n+"是数组中第"+j+"个数");
}
}
}

折半查找,binarySearch的更多相关文章

  1. 二分查找BinarySearch(Java)

    二分查找(折半查找)BinarySearch 二分查找  一组排好顺序的数,查找其中的一个数(value)的位置,按照数组(int[] a)存放这组数据,数组的索引所指的位置就是需要查找的数,用三个变 ...

  2. [转]编程珠玑第五章二分搜索(折半查找)之java实现

    http://blog.csdn.net/hwe_xc/article/details/51813080 二分搜索又称为折半查找,用来高效快速的解决如下问题: 我们需要确定排序后的数组x[0..n-1 ...

  3. Java实现冒泡排序、折半查找

    1.冒泡排序 public class BubbleSort{ public static void main(String[] args){ int score[] = {67, 69, 75, 8 ...

  4. java基础-数组的折半查找原理

    java基础-数组的折半查找原理 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 如果让你写一个数组的查找功能,需求如下:在一个数组中,找一个元素,是否存在于数组中, 如果存在就返回 ...

  5. C++实现顺序查找,折半查找,插值查找

    1.顺序查找 从数组起始扫描到数组结尾,判断该索引数组是否和关键字相等,成功返回1 代码如下: //顺序查找 int seqSearch(int *array, int low, int high, ...

  6. 算法笔记_026:折半查找(Java)

    目录 1 问题描述 2 解决方案 2.1 递归法 2.2 迭代法 1 问题描述 首先,了解一下何为折半查找?此处,借用<算法设计与分析基础>第三版上一段文字介绍: 2 解决方案 2.1 递 ...

  7. Java实现三种常用的查找算法(顺序查查找,折半查找,二叉排序树查找)

    public class Search { public class BiTreeNode{ int m_nValue; BiTreeNode m_pLeft; BiTreeNode m_pRight ...

  8. 折半查找——Java实现

    一.查找思想 折半查找 也称为二分查找,是一种效率较高的查找方法,查找时要求表中的节点按关键字的大小排序,并且要求线性表顺序存储. 首先用要查找的关键字值(key)与中间位置结点的关键字值(arr[m ...

  9. Java学习笔记day07_琐碎知识_水仙花数_ASCII码_冒泡排序_简单选择排序_折半查找

    琐碎知识: 水仙花数, ASCII码, 冒泡排序, 简单选择排序, 折半查找 1.水仙花数 每位数的平方的和等于本身. 如100到999之间的水仙花数满足: 个位的平方+十位的平方+百位的平方 = 本 ...

随机推荐

  1. Dubbo端口占用错误信息

    SEVERE: Exception sending context initialized event to listener instance of class com.common.SysCont ...

  2. C++ 自定义结构体的Priority Queue

    比较函数return true 意味着排序需要交换. #include <iostream> #include <queue> #include <vector> ...

  3. 排错:expected unqualified-id before string constant

    一个低级但是不好定位的编译错误,常见的问题是: 1. 语句的 { 括号不匹配. 2. 缺少 : , 特别是类的定义或声明,枚举的定义. 3. 变量名或函数名使用了保留字.

  4. 1049 - Deg-route

    http://www.ifrog.cc/acm/problem/1049 这些数学题我一般都是找规律的.. 先暴力模拟了前面的那些,然后发现(x, y) = (x, y - 1) + (x - 1, ...

  5. vuex 使用方法

    1.安装vuex扩展 : npm install vuex 2.在componets目录下新建 store.js 文件 import Vue from 'vue' import Vuex from ' ...

  6. autofac 遇到构造函数问题

    None of the constructors found with 'aaaaa' on type ' aaa' can be invoked with the available service ...

  7. [文章泛读] The varying faces of a program transformation systems (ACM Inroads, 2012)

    Beevi S. Nadera, D. Chitraprasad, and Vinod S. S. Chandra. 2012. The varying faces of a program tran ...

  8. Dijkstra算法——单源最短路算法

    一.介绍 迪杰斯特拉(Dijkstra)算法是典型最短路径算法,用于计算一个节点到其他各个节点的最短路径. 它的主要特点是以起始点为中心向外层层扩展(广度优先搜索思想),直到扩展到终点为止. 适用于有 ...

  9. Jarvis OJ-Smashes

    栈溢出之利用-stack-chk-fail from pwn import * old_flag_addr = 0x600d20 new_flag_addr = 0x400d20 #p = proce ...

  10. PAT (Advanced Level) Practise - 1098. Insertion or Heap Sort (25)

    http://www.patest.cn/contests/pat-a-practise/1098 According to Wikipedia: Insertion sort iterates, c ...