java数据结构之有序表查找
这篇文章是关于有序表的查找,主要包括了顺序查找的优化用法、折半查找、插值查找、斐波那契查找;
顺序优化查找:效率极为底下,但是算法简单,适用于小型数据查找;
折半查找:又称为二分查找,它是从查找表的中间开始查找。查找结果只需要找其中一半的数据记录即可。效率较顺序查找提高不少。比较适用与静态表,一次排序后不在变化;
插值查找:与折半查找比较相似,只是把中间之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数据结构之有序表查找的更多相关文章
- Java数据结构之线性表
从这里开始将要进行Java数据结构的相关讲解,Are you ready?Let's go~~ java中的数据结构模型可以分为一下几部分: 1.线性结构 2.树形结构 3.图形或者网状结构 接下来的 ...
- Java数据结构之线性表(2)
从这里开始将要进行Java数据结构的相关讲解,Are you ready?Let's go~~ java中的数据结构模型可以分为一下几部分: 1.线性结构 2.树形结构 3.图形或者网状结构 接下来的 ...
- java 数据结构与算法 之查找法
一.二分查找法 二分查找就是将查找的键和子数组的中间键作比较,如果被查找的键小于中间键,就在左子数组继续查找:如果大于中间键,就在右子数组中查找,否则中间键就是要找的元素. @Test public ...
- JAVA数据结构--哈希表的实现(分离链接法)
哈希表(散列)的定义 散列表(Hash table,也叫哈希表),是根据关键码值(Key value)而直接进行访问的数据结构.也就是说,它通过把关键码值映射到表中一个位置来访问记录,以加快查找的速度 ...
- java数据结构----哈希表
1.哈希表:它是一种数据结构,可以提供快速的插入操作和查找操作.如果哈希表中有多少数据项,插入和删除操作只需要接近常量的时间.即O(1)的时间级.在计算机中如果需要一秒内查找上千条记录,通常使用哈希表 ...
- java数据结构之hash表
转自:http://www.cnblogs.com/dolphin0520/archive/2012/09/28/2700000.html Hash表也称散列表,也有直接译作哈希表,Hash表是一种特 ...
- 【数据结构】 顺序表查找(折半查找&&差值查找)
#include <stdio.h> #include <stdlib.h> #include <time.h> #define MAXSIZE 10 首先构造一个 ...
- java数据结构——哈希表(HashTable)
哈希表提供了快速的插入操作和查找操作,每一个元素是一个key-value对,其基于数组来实现. 一.Java中HashMap与Hashtable的区别: HashMap可以接受null键值和值,而Ha ...
- Java数据结构-01顺序表
一.定义 线性表是一种线性结构,它是具有相同类型的n(n≥0)个数据元素组成的有限序列. 二.存储分类 1.顺序存储: ①简述:是指将线性表中的各个元素依次存放在一组地址连续的存储单元中,通常将这种方 ...
随机推荐
- Openjudge-计算概论(A)-整数的个数
描述: 给定k(1<k<100)个正整数,其中每个数都是大于等于1,小于等于10的数.写程序计算给定的k个正整数中,1,5和10出现的次数.输入输入有两行:第一行包含一个正整数k,第二行包 ...
- Openjudge-计算概论(A)-判断闰年
描述: 判断某年是否是闰年.输入输入只有一行,包含一个整数a(0 < a < 3000)输出一行,如果公元a年是闰年输出Y,否则输出N样例输入 2006 样例输出 N 提示:公历纪年法中, ...
- 动态封杀与解封IP
不论IIS6还是IIS7 都可以把需要封杀的IP加入封杀列表.但是需要注意的是我们代码写的是全部替换原先的数据.但是在IIS7下,执行的效果是原先的不替换,新加一批封杀 IP.当然IIS7下,如果新加 ...
- ios 字符串的操作汇总
//将NSData转化为NSString NSString* str = [[NSString alloc] initWithData:response encoding:NSUTF8S ...
- HyperSnap(屏幕抓图工具) 8.11.03 官方简体中文特别版
软件名称:屏幕抓图工具HyperSnap 软件分类:图像捕捉运行环境:WinXP/Win2003/Vista/Win7/Win8/WinALL软件语言:简体中文授权方式:免费软件软件大小:12462K ...
- ural 1698. Square Country 5(记忆化搜索)
1698. Square Country 5 Time limit: 2.0 secondMemory limit: 64 MB The first arithmetical operation ta ...
- CentOS的KVM实践(虚拟机创建、网桥配置、Spice)
最近公司准备上一套基于openstack的虚拟桌面系统,作为该项目的负责人,觉得有必要自己实践一下,该系统的搭建.最基础的就是需要了解基于linux的kvm的实践. 一.基础软件包准备 系统是采用px ...
- 照着例子学习protobuf-python
以下是照着python操作protobuf进行的protobuf-python的学习笔记: 首先是protobuf的下载与安装: 1 由于google被墙,所以去github上面搜索了一下protob ...
- 【01-14】java ThreadLocal工具类
自定义ThreadLocal package concurrent; import java.util.HashMap; import java.util.Map; /** * @author alo ...
- HTTP Keep-Alive详解[转]
HTTP是一个请求<->响应模式的典型范例,即客户端向服务器发送一个请求信息,服务器来响应这个信息.在老的HTTP版本中,每个请求都将被创建一个新的客户端->服务器的连接,在这个连接 ...