算法笔记_026:折半查找(Java)
目录
1 问题描述
首先,了解一下何为折半查找?此处,借用《算法设计与分析基础》第三版上一段文字介绍:

2 解决方案
2.1 递归法
具体代码如下:
package com.liuzhen.chapter4;
public class BinarySearch {
    //方法1:递归求解
    public void recursionSearch(int[] A,int start,int end,int number){
        int mid = (start + end)/2;
        if(A[mid] == number)
            System.out.println("使用递归法求取number = "+number+"的数组下标结果:"+mid);
        if(A[mid] > number)
            recursionSearch(A,start,mid-1,number);   //递归调用
        if(A[mid] < number)
            recursionSearch(A,mid+1,end,number);     //递归调用
    }
    public static void main(String[] args){
        BinarySearch test = new BinarySearch();
        int[] A = {3,14,27,31,39,42,55,70,74,81,85,93,98};
        test.recursionSearch(A, 0, A.length-1, 70);
    }
}
运行结果:
使用递归法求取number = 70的数组下标结果:7
2.2 迭代法
具体代码如下:
package com.liuzhen.chapter4;
public class BinarySearch {
    //方法2:迭代求解
    public int iterationSearch(int[] A,int number){
        int start = 0;
        int end = A.length-1;
        while(start <= end){
            int mid = (start + end)/2;
            if(A[mid] == number)
                return mid;
            if(A[mid] > number)
                end = mid-1;
            if(A[mid] < number)
                start = mid+1;
        }
        return -1;
    }
    public static void main(String[] args){
        BinarySearch test = new BinarySearch();
        int[] A = {3,14,27,31,39,42,55,70,74,81,85,93,98};
        System.out.println("使用迭代法求解number = 70的数组下标结果:"+test.iterationSearch(A, 70));
    }
}
运行结果:
使用迭代法求解number = 70的数组下标结果:7
算法笔记_026:折半查找(Java)的更多相关文章
- 算法笔记_018:旅行商问题(Java)
		
目录 1 问题描述 2 解决方案 2.1 蛮力法 2.2 减治法 2.2.1 Johson-Trotter算法 2.2.2 基于字典序的算法 1 问题描述 何为旅行商问题?按照非专业的说法,这个问 ...
 - 折半查找——Java实现
		
一.查找思想 折半查找 也称为二分查找,是一种效率较高的查找方法,查找时要求表中的节点按关键字的大小排序,并且要求线性表顺序存储. 首先用要查找的关键字值(key)与中间位置结点的关键字值(arr[m ...
 - 算法笔记_021:广度优先查找(Java)
		
目录 1 问题描述 2 解决方案 2.1 蛮力法 1 问题描述 广度优先查找(Breadth-first Search,BFS)按照一种同心圆的方式,首先访问所有和初始顶点邻接的顶点,然后是离它两条边 ...
 - 算法笔记_020:深度优先查找(Java)
		
目录 1 问题描述 2 解决方案 2.1 蛮力法 1 问题描述 深度优先查找(depth-first search,DFS)可以从任意顶点开始访问图的顶点,然后把该顶点标记为已访问.在每次迭代的时候, ...
 - 算法笔记_019:背包问题(Java)
		
目录 1 问题描述 2 解决方案 2.1 蛮力法 2.2 减治法 2.2.1 递归求解 2.2.2 非递归求解(运用异或运算) 2.3 动态规划法 1 问题描述 给定n个重量为w1,w2,w3,... ...
 - 算法---区间K大数查找 Java 蓝桥杯ALGO-1
		
import java.util.Arrays; import java.util.Scanner; public class Main { public static void main(Strin ...
 - 算法笔记_015:快速排序(Java)
		
目录 1 问题描述 2 解决方案 2.1 快速排序原理简介 2.2 具体编码 1 问题描述 给定一组数据,使用快速排序得到这组数据的非降序排列. 2 解决方案 2.1 快速排序原理简介 引用自百度百科 ...
 - 算法笔记_230:运动员分组(Java)
		
目录 1 问题描述 2 解决方案 1 问题描述 有N个人参加100米短跑比赛.跑道为8条.程序的任务是按照尽量使每组的人数相差最少的原则分组.例如:N=8时,分成1组即可.N=9时,分成2组:一组 ...
 - 算法笔记_136:交替字符串(Java)
		
目录 1 问题描述 2 解决方案 1 问题描述 输入三个字符串s1.s2和s3,判断第三个字符串s3是否由前两个字符串s1和s2交错而成且不改变s1和s2中各个字符原有的相对顺序. 2 解决方案 ...
 
随机推荐
- [BZOJ4247]挂饰(DP)
			
当最终挂饰集合确定了,一定是先挂挂钩多的在挂挂钩少的. 于是按挂钩从大到小排序,然后就是简单的01背包. #include<cstdio> #include<algorithm> ...
 - 【最大化平均值】POJ3111-K Best
			
[题目大意] 给出v[]和w[],求的最大值. [思路] 二分s(S)的值,可变形为s(S)*Σw>=Σv,所以只需要把求出x*w[i]-v[i],看看前k个的和是否大于等于0,大于等于0就满足 ...
 - 两个函数彻底理解Lua中的闭包
			
本文通过两个函数彻底搞懂Lua中的闭包,相信看完这两个函数,应该能理解什么是Lua闭包.废话不多说,上 code: --[[************************************** ...
 - noip2013 车站分级
			
题目描述 一条单向的铁路线上,依次有编号为 1, 2, …, n1,2,…,n的 nn个火车站.每个火车站都有一个级别,最低为 11 级.现有若干趟车次在这条线路上行驶,每一趟都满足如下要求:如果这趟 ...
 - python 读写txt文件并用jieba库进行中文分词
			
python用来批量处理一些数据的第一步吧. 对于我这样的的萌新.这是第一步. #encoding=utf-8 file='test.txt' fn=open(file,"r") ...
 - EM(Expectation Maximization)算法
			
EM(Expectation Maximization)算法 参考资料: [1]. 从最大似然到EM算法浅解 [2]. 简单的EM算法例子 [3]. EM算法)The EM Algorithm(详尽 ...
 - win2003服务器装spl2008,打安全补丁后无法进入SQL Server Management Studio
			
解决方法就是:卸载垃圾的360安全卫士,用windows自带的更新工具更新系统补丁,就好了
 - 数组、Set对象的互相转换
			
一.数组与Set对象之间的转换可以实现数组的去重(数组可重复,Set不可重复) 1. 把数组对象转换为Set对象 var arr = [1,2,3,4,5,6,7,6,6,7]; console.lo ...
 - 【资料】wod烟草
			
注意: 1. 所有效果持续时间是整个地城 2. 某几样菸草在使用 烟雾的祝福 的时候效果只有LV1 (技能 -25), 表示该物品设计上主要是自己使用而非加给团队. SL = 技能等级 HL = 英雄 ...
 - js+Ajax,Get和Post在使用上的区别
			
get和post方法最大的不同在于: 1.get方法传值参数在url里面,而post参数放send里面 2.post方法必须加上 xmlHttp.setRequestHeader("Cont ...