java 二分法_java实现二分法的完整代码
二分法查找,顾名思义就是要将数据每次都分成两份然后再去找到你想要的数据,我们可以这样去想,二分法查找很类似与我们平时玩的猜价格游戏,当你报出一个价格时裁判会告诉你价格相对于真实值的高低,倘若是低了那我们一定会再说出一个略高的价格,反之亦然。在二分法查找时要求传入的数据必须已经有序,假设现在为升序,然后每次将所寻找的值与中间值(数组左边界+(右边界-左边界)/2)作比较,大了则去寻找中间值左侧数据,小则寻找中间值右侧数据。
二分法查找比较局限性的就是只能操作一个已经排序了的数组。
方法一
下面为一个二分法实现的完整代码
package dichotomy;
import java.util.Arrays;
import java.util.Scanner;
import static java.lang.System.out;
public class Erchange {
private static Scanner in;
public int find(int a[],int b) //a为所要查找的数
{
int mid,low=0,high;
high=a.length-1;
while(low<=high)
{
mid=low+(high-low)/2;
if(b
{
high=mid-1;
}
else if(b>a[mid])
{
low=mid+1;
}
else
{
return mid+1;
}
}
return 0;
}
public static void main(String[] args) {
int a[];
int t;
int sum=0;
Erchange p=new Erchange();
int q2 = 0;
in = new Scanner(System.in);
out.println("请输入数组长度");
q2= in.nextInt();
a=new int [q2];
out.println("请输入数组元素");
for(int i=0;i
{
a[i]=in.nextInt();
}
out.println("排序后数组为");
Arrays.sort(a);
for (int i = 0; i < a.length; i++) {
out.print(a[i]+" ");
}
out.println();
out.println("请输入所要查找的数若未查找到该数则输出-1");
q2=in.nextInt();
for(int i=0;i
{
if(q2==a[i])
{
t=1;
}
else
{
t=0;
}
sum=sum+t;
}
if(sum==0)
{
out.println("-1");
}
else
{
out.println("所输入的数在第"+p.find(a,q2)+"位");
}
}
方法二
代码实现:
public class BinarySearch {
//进行二分法查找的前提是数组已经有序!
public static int rank(int key,int nums[])
{
//查找范围的上下界
int low=0;
int high=nums.length-1;
//未查找到的返回值
int notFind=-1;
while(low<=high)
{
//二分中点=数组左边界+(右边界-左边界)/2
//整数类型默认取下整
int mid=low+(high-low)/2;
//中间值是如果大于key
if(nums[mid]>key)
{
//证明key在[low,mid-1]这个区间
//因为num[mid]已经判断过了所以下界要减一
high=mid-1;
}else if(nums[mid]
{
//证明key在[mid+1,high]这个区间
//同样判断过mid对应的值要从mid+1往后判断
low=mid+1;
}
else
{
//查找成功
return mid;
}
}
//未成功
return notFind;
}
public static void main(String[] args) {
System.out.println("请输入数据数量:");
Scanner scanner=new Scanner(System.in);
int amount=scanner.nextInt();
int num;
int nums[]=new int[amount];
int i=0;
while(i
{
nums[i]=scanner.nextInt();
i++;
}
Arrays.sort(nums);
System.out.println("请输入想要查找的值");
int key=scanner.nextInt();
int answer=rank(key,nums);
if(answer!=-1)
{
System.out.println("所查找的数据存在:"+nums[answer]);
}
else
{
System.out.println("您所查找的数据不存在");
}
}
}
方法三、算法代码实现之二分法查找
封装成类:
package com.roc.algorithms.search;
/**
* 二分法查找
*
* @author roc
*/
public class BinarySearch {
/**
* @param a 升序排列的数组
* @param k 待查找的整数
* @return 如果查到有就返回对应角标,没有就返回-1
*/
public static int search(int[] a, int k) {
int lo = 0, hi = a.length - 1;
while (lo <= hi) {
int m = (lo + hi) >> 1;
if (a[m] < k) {
lo = m + 1;
} else if (a[m] > k) {
hi = m - 1;
} else {
return m;
}
}
return -1;
}
}
测试:
int[] a = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
System.out.println(BinarySearch.search(a, 6));
输出:
6
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
java 二分法_java实现二分法的完整代码相关推荐
- 【Java】Java基础飞机大战小游戏完整代码
Java基础飞机大战小游戏完整代码 先来展示一下代码实现结果图 主函数ShootGame 初始化游戏原始背景图片,游戏人物图片,游戏开始结束图片:构建产生敌人算法:产生英雄机算法:发射子弹算法:判断是 ...
- Java实现智能语音朗读(完整代码+EXE程序制作)
注意 本文主要介绍整个实现过程,一步一步跟着做,相信大家都可以完成的比我好.想要完整代码的可以跳过文章直接去文末获取,如果想要在本机上运行,请首先搭建好环境,如何搭建环境在项目的第二阶段里面. 概述 ...
- java 编码 正弦计算器_计算器完整代码(java).doc
计算器完整代码(java) 1. Calculator 类 import java.applet.*; import java.awt.*; import java.awt.event.*; impo ...
- Java实现单机五子棋,含完整代码
文章目录 五子棋!! 实现功能 改进方向 主体思路 遇到的困难 完整代码 五子棋!! 实现功能 基本的棋盘绘制,重绘,输赢判断,悔棋,重新开始 改进方向 添加背景音乐,背景图片美化,用棋子图片代替原棋 ...
- java 教师工资管理系统_java教师工资管理系统完整代码.doc
教师工资管理系统: 开发团队:206和207 时间:2012年4月8日 数据库配置:sqlserver2000 创建数据库SalaryManagement 在其下创建数据表logindata. 创建数 ...
- Spark中Data skew(数据倾斜)Java+Python+Scala三种接口完整代码
起因 代码中shuffle的算子存在的地方,groupByKey.countByKey.reduceByKey.join等 判断一个算子是shuffle算子可以通过[20] 出现的问题有两种 ①大部分 ...
- JAVA集合详解(附完整代码)
Collections(集合) 一.常用的集合相关接口与实现类 在Java中所有的集合类都源自Iterable接口,Colletion继承Iterable接口,Collection下有三个子接口, ...
- java计算机全部代码_(Java)谁有计算器的完整代码?
展开全部 参考: http://gzdzw.51.net/htmjsq.htm 计算器代码: 计算器 var FKeyPad = document.Calculator; var Accum = 0; ...
- java图像增强_java图片对比度调整示例代码
前言 本文主要给大家介绍了关于java图片对比度调整的方法,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧 方法如下 测试代码 public static void main(Stri ...
最新文章
- python 为什么用%格式化_Python中应该使用%还是format来格式化字符串?
- RobotFramework教程使用笔记——requests和requestslibrary库
- 在linux下Qt使用sqlite,QT中SQLite使用【实例】
- python学习历程-安装篇(一)
- java 18 -4 LinkedHashMap集合
- spring连接jdbc_在Spring JDBC中添加C3PO连接池
- 忘记 mysql 密码的取回方法
- 银行转账java mysql_一个银行转账业务模型分析:大魏Java记5-7
- 微信小程序傻瓜制作_从15款工具中精选出4款,最靠谱的微信小程序制作软件!...
- smartsvn 忽略文件夹_设置SVN忽略文件和目录(文件夹)
- JPA整合达梦数据库
- 安装软件时提示“系统管理员设置策略禁止此安装”,解决方案
- grammarly word安装失败
- 【Try to Hack】veil-evasion免杀
- 我的世界 MineCraft RPG 服务器版本选择不完全指北 (内含 我的世界 版本更新内容盘点)
- 关于地理坐标的精度设置,做测绘的工程师应该懂的基本常识(南方数码CASS11.0.0.6还增加批量转换的方式)
- [CodeForces] 274E Mirror Room
- 第8章 面向对象编程(中级部分)
- php中switch语句的理解,php中switch语句的使用详解
- Python批量处理Excel办公自动化