这篇文章是关于有序表的查找,主要包括了顺序查找的优化用法、折半查找、插值查找、斐波那契查找;

顺序优化查找:效率极为底下,但是算法简单,适用于小型数据查找;

折半查找:又称为二分查找,它是从查找表的中间开始查找。查找结果只需要找其中一半的数据记录即可。效率较顺序查找提高不少。比较适用与静态表,一次排序后不在变化;

插值查找:与折半查找比较相似,只是把中间之mid的公式进行了变换将mid = (low+high)/2;换成了mid = low + (high - low) * (key - sum[low]) / (sum[high] - sum[low]);

插值查找的效率比折半查找的效率又要高出不少,比较适用与表长较大,而关键字又分布得比较均匀的表查找;

斐波那契查找:是利用了黄金分割的原理来进行查找,平均性能要由优于折半查找,但是如果时最坏的情况,则效率低于折半查找(要查找的关键字一直比较靠近黄金分割较长的那一                             段),但是运算比较简单,只有最简单的加减运算;

代码实现:

 /**
* 查找
* 2016/5/1
*
**/
package cn.Link; public class Search {
public static void main(String [] args){
int n = 10; //数组长度
int key = 18; //查找关键数
int sum[] = new int[n];//有序数组 for(int i = 0;i < n;i++ ){
sum[i] = i*2;
}
System.out.println("本程序由于查找值为key的数组下标,如果返回负数,则表示没有找到,");
//打印sum数组
System.out.print("sum数组:");
for(int u: sum){
System.out.print(u+" ");
}
System.out.println("\n要查找的数为:"+key); int result = Sequential_Serach(sum,n,key);
System.out.println("\n顺序优化查找结果:"+result);
result = Binary_Serach(sum,n,key);
System.out.println("折半查找查找结果:"+result);
result = Interpolation_Serach(sum,n,key);
System.out.println("插值查找查找结果:"+result);
result = Fibonacci_Serach(sum,n,key);
System.out.println("斐波那契查找结果:"+result); } //顺序优化查找
public static int Sequential_Serach(int sum[],int n, int key){
if(key >sum[n-1] || key < sum[0])
return -1; //sum为从小到大排列,如果key大于sum[n-1]或小于sum[0]则肯定找不到 int i;
int sum_1 = sum[0]; //记录sum首位值,用以在程序结束时还原
sum[0] = key;
i = n-1;
while(sum[i] != key){
i--;
}
sum[0] = sum_1;
if(i !=0 ){
return i;
}else{
return -1;
}
} //折半查找
public static int Binary_Serach(int sum[],int n,int key){
if(key >sum[n-1] || key < sum[0])
return -1; //sum为从小到大排列,如果key大于sum[n-1]或小于sum[0]则肯定找不到 int low = 0;
int high = n-1;
int mid ;
while(low <= high){
mid = (low+high)/2;
if(key < sum[mid]){
high = mid -1;
}else if(key > sum[mid]){
low = mid +1;
}else{
return mid;
}
}
return -1;
} //插值查找 与折半查找只有mid的得到结果一行代码不同 优势:查找表长比较大,而关键字分布又比价均匀的查找表时平均性能比折半查找要好
public static int Interpolation_Serach(int sum[],int n,int key){ if(key >sum[n-1] || key < sum[0])
return -1; //sum为从小到大排列,如果key大于sum[n-1]或小于sum[0]则肯定找不到
if(sum[0] == sum[n-1]) return 0; //首数和尾数相等 这是一个所有数都想等的数组 没有这一步的话会发生除零错误 int low = 1;
int high = n-1;
int mid ;
while(low <= high){
mid = low + (high - low) * (key - sum[low]) / (sum[high] - sum[low]);
if(key < sum[mid]){
high = mid -1;
}else if(key > sum[mid]){
low = mid +1;
}else{
return mid;
}
}
return -1;
} //斐波那契查找 平均性能要由优于折半查找,但是如果时最坏的情况,则效率低于折半查找如key=2
public static int Fibonacci_Serach(int sum[],int n,int key){
if(key >sum[n-1] || key < sum[0])
return -1; //sum为从小到大排列,如果key大于sum[n-1]或小于sum[0]则肯定找不到 int low, high, mid, i, k;
low = 0;
high = n-1;
k = 0;
int F[] = new int[n];
F[0] = 0;
F[1] = F[2] = 1;
for(i = 3;i < n;i++){ //建立一个斐波那契数列,理论上这个数组是无限长的
F[i] = F[i-1] + F[i-2];
}
while(n > F[k]-1){ //计算n位于斐波那契数列的位置
k++;
} int[] sum_1 = new int[F[k]-1]; //增加数组的长度
for(i = 0;i < F[k]-1;i++){ //将不满的数值补全
if(i < n){
sum_1[i] = sum[i];
}else{
sum_1[i] = sum[n-1];
}
} while ( low <= high ){
mid = low+F[k-1]-1;
if(key < sum_1[mid]){
high = mid-1;
k = k-1;
}else if(key > sum_1[mid]){
low = mid + 1;
k = k-2;
}else{
if(mid < n ){
return mid; //找到了这个数
}else{
return n-1; //如果差找到的数在sum[n-1]以后返回sum最后一个数
}
}
}
return -1;
}
}

java数据结构之有序表查找的更多相关文章

  1. Java数据结构之线性表

    从这里开始将要进行Java数据结构的相关讲解,Are you ready?Let's go~~ java中的数据结构模型可以分为一下几部分: 1.线性结构 2.树形结构 3.图形或者网状结构 接下来的 ...

  2. Java数据结构之线性表(2)

    从这里开始将要进行Java数据结构的相关讲解,Are you ready?Let's go~~ java中的数据结构模型可以分为一下几部分: 1.线性结构 2.树形结构 3.图形或者网状结构 接下来的 ...

  3. java 数据结构与算法 之查找法

    一.二分查找法 二分查找就是将查找的键和子数组的中间键作比较,如果被查找的键小于中间键,就在左子数组继续查找:如果大于中间键,就在右子数组中查找,否则中间键就是要找的元素. @Test public ...

  4. JAVA数据结构--哈希表的实现(分离链接法)

    哈希表(散列)的定义 散列表(Hash table,也叫哈希表),是根据关键码值(Key value)而直接进行访问的数据结构.也就是说,它通过把关键码值映射到表中一个位置来访问记录,以加快查找的速度 ...

  5. java数据结构----哈希表

    1.哈希表:它是一种数据结构,可以提供快速的插入操作和查找操作.如果哈希表中有多少数据项,插入和删除操作只需要接近常量的时间.即O(1)的时间级.在计算机中如果需要一秒内查找上千条记录,通常使用哈希表 ...

  6. java数据结构之hash表

    转自:http://www.cnblogs.com/dolphin0520/archive/2012/09/28/2700000.html Hash表也称散列表,也有直接译作哈希表,Hash表是一种特 ...

  7. 【数据结构】 顺序表查找(折半查找&&差值查找)

    #include <stdio.h> #include <stdlib.h> #include <time.h> #define MAXSIZE 10 首先构造一个 ...

  8. java数据结构——哈希表(HashTable)

    哈希表提供了快速的插入操作和查找操作,每一个元素是一个key-value对,其基于数组来实现. 一.Java中HashMap与Hashtable的区别: HashMap可以接受null键值和值,而Ha ...

  9. Java数据结构-01顺序表

    一.定义 线性表是一种线性结构,它是具有相同类型的n(n≥0)个数据元素组成的有限序列. 二.存储分类 1.顺序存储: ①简述:是指将线性表中的各个元素依次存放在一组地址连续的存储单元中,通常将这种方 ...

随机推荐

  1. 7 个 jQuery 最佳实践

    前言 随着富网络应用(rich web applications)数量的增长,以及用户对快速交互响应的高期望,开发者开始使用JavaScript库来快速高效的完成一些重复性的工作.这其中最流行的Jav ...

  2. kissy小记

    <script> KISSY.add('demo',function(S ,require, exports, module){ var Node = require('node'); v ...

  3. ios navigationController代码创建

    1.新建类文件FirstViewController,subClass of:UIViewController 2.新建类文件MYNavigationController,subClass of:UI ...

  4. MVC DisplayTemplates and EdiotrTemplates.

    我们在mvc项目里经常要对枚举,日期,副文本输入,我们可以用笨拙的方法去view页面里绑定呈现的html内容,而且这种办法不能重用,也就是在不同的view里还是需要做相同的事情,给个日期空间选择例子吧 ...

  5. Latex 中插入图片no bounding box 解决方案

    在windows下,用latex插入格式为jpg,png等图片会出现no bounding box 的编译错误,此时有两个解决办法: 1.将图片转换为eps格式的图片 \usepackage{grap ...

  6. DirectShow音频采集声音不连续问题分析与解决办法经验总结

    最近广州大雨不断,并且多数无前兆,突然就来场大雨,给同学们降降温,说来本也是好事,但有时候下的真不是时候,最近这段时间都是即将下班了,大雨就来了,昨晚快下班前又出现了大雨,北方人总爱忘带雨伞,这不就被 ...

  7. 在CentOS7部署zookeeper集群以及简单API使用

    一.部署zookeeper集群 zookeeper是一个针对大型分布式系统的协调系统,提供的功能有统一名称服务.分布式同步等. 1.上传zk安装包 2.解压     tar -xzvf zookeep ...

  8. Strusts2--课程笔记5

      数据验证: 输入验证分为客户端验证与服务器端验证.客户端验证主要通过JavaScript脚本进行,而服务器端验证主要是通过Java代码进行验证. 分为以下四种情况: (1)手工编写代码,对所有Ac ...

  9. android 按钮Button单击背景切换

    res/drawable/btn_selected.xml <?xml version="1.0" encoding="utf-8"?> <s ...

  10. HttpUtil工具类

    HttpUtil工具类 /** * 向指定URL发送GET方法的请求 * * @param url * 发送请求的URL * @param params * 请求参数,请求参数应该是name1=val ...