1.顺序查找
/**顺序查找平均时间复杂度 O(n)
* @param searchKey 要查找的值
* @param array 数组(从这个数组中查找)
* @return 查找结果(数组的下标位置)
*/
public static int orderSearch(int searchKey,int[] array){
if(array==null||array.length<1)
return -1;
for(int i=0;i<array.length;i++){
if(array[i]==searchKey){
return i;
}
}
return -1;
}
2.二分查找
/**
* 二分查找又称折半查找,它是一种效率较高的查找方法。 【二分查找要求】:1.必须采用顺序存储结构 2.必须按关键字大小有序排列。
*
* @param array
* 有序数组 *
* @param searchKey
* 查找元素 *
* @return searchKey的数组下标,没找到返回-1
*/
public static int binarySearch(int[] array, int searchKey) {
int low = 0;
int high = array.length - 1;
while (low <= high) {
int middle = (low + high) / 2;
if (searchKey == array[middle]) {
return middle;
} else if (searchKey < array[middle]) {
high = middle - 1;
} else {
low = middle + 1;
}
}
return -1;
}
3.分块查找
a. 首先将查找表分成若干块,在每一块中数据元素的存放是任意的,但块与块之间必须是有序的(假设这种排序是按关键字值递增的,也就是说在第一块中任意一个数据元素的关键字都小于第二块中所有数据元素的关键字,第二块中任意一个数据元素的关键字都小于第三块中所有数据元素的关键字,依次类推);
b. 建立一个索引表,把每块中最大的关键字值按块的顺序存放在一个辅助数组中,这个索引表也按升序排列;
c. 查找时先用给定的关键字值在索引表中查找,确定满足条件的数据元素存放在哪个块中,查找方法既可以是折半方法,也可以是顺序查找。
d. 再到相应的块中顺序查找,便可以得到查找的结果。
/**
* 分块查找
*
* @param index
* 索引表,其中放的是各块的最大值
* @param st
* 顺序表,
* @param key
* 要查找的值
* @param m
* 顺序表中各块的长度相等,为m
* @return
*/
public static int blockSearch(int[] index, int[] st, int key, int m) {
// 在序列st数组中,用分块查找方法查找关键字为key的记录
// 1.在index[ ] 中折半查找,确定要查找的key属于哪个块中
int i = binarySearch(index, key);
if (i >= 0) {
int j = i > 0 ? i * m : i;
int len = (i + 1) * m;
// 在确定的块中用顺序查找方法查找key
for (int k = j; k < len; k++) {
if (key == st[k]) {
System.out.println("查询成功");
return k;
}
}
}
System.out.println("查找失败");
return -1;
}
4.哈希查找
哈希表查找是通过对记录的关键字值进行运算,直接求出结点的地址,是关键字到地址的直接转换方法,不用反复比较。假设f包含n个结点,Ri为其中某个结点(1≤i≤n),keyi是其关键字值,在keyi与Ri的地址之间建立某种函数关系,可以通过这个函数把关键字值转换成相应结点的地址,有:addr(Ri)=H(keyi),addr(Ri)为哈希函数。
解决冲突的方法有以下两种:
(1)开放地址法
如果两个数据元素的哈希值相同,则在哈希表中为后插入的数据元素另外选择一个表项。当程序查找哈希表时,如果没有在第一个对应的哈希表项中找到符合查找要求的数据元素,程序就会继续往后查找,直到找到一个符合查找要求的数据元素,或者遇到一个空的表项。
(2)链地址法
将哈希值相同的数据元素存放在一个链表中,在查找哈希表的过程中,当查找到这个链表时,必须采用线性查找方法。
/****
* Hash查找
*
* @param hash
* @param hashLength
* @param key
* @return
*/
public static int searchHash(int[] hash, int hashLength, int key) {
// 哈希函数
int hashAddress = key % hashLength;
// 指定hashAdrress对应值存在但不是关键值,则用开放寻址法解决
while (hash[hashAddress] != 0 && hash[hashAddress] != key) {
hashAddress = (++hashAddress) % hashLength;
}
// 查找到了开放单元,表示查找失败
if (hash[hashAddress] == 0)
return -1;
return hashAddress;
}
/***
* 数据插入Hash表
*
* @param hash
* 哈希表
* @param hashLength
* @param data
*/
public static void insertHash(int[] hash, int hashLength, int data) {
// 哈希函数
int hashAddress = data % hashLength;
// 如果key存在,则说明已经被别人占用,此时必须解决冲突
while (hash[hashAddress] != 0) {
// 用开放寻址法找到
hashAddress = (++hashAddress) % hashLength;
}
// 将data存入字典中
hash[hashAddress] = data;
}
分享到:
相关推荐
在Java编程语言中,实现哈希算法可以方便地用于数据验证、查找表以及密码存储等多种用途。本篇文章将详细讨论几种常见的哈希算法及其在Java中的实现。 1. **MD5(Message-Digest Algorithm 5)** MD5是一种广泛...
AlgorithmGossip是一个非常有价值的资源集合,它包含了众多常用算法的C和Java实现。这个压缩包旨在为学习者和开发者提供一个实践和理解算法的平台,无论是初学者还是经验丰富的程序员,都能从中受益。 首先,我们要...
这个"Java常用数值算法集"很可能提供了上述算法的Java实现,让开发者可以直接在Java项目中使用。理解并熟练掌握这些算法,不仅可以提升编程技能,还能增强解决实际问题的能力。同时,CHM文件是一种Windows帮助文档...
Java实现k近邻(kNN)算法是机器学习领域中一种基础且重要的算法,主要用于分类和回归问题。kNN算法基于实例的学习,它不预先建立任何模型,而是将新数据分类或预测为与其最近的k个训练样本中最常见的类别。在这个讨论...
LRU(Least Recently Used)算法是一种常用的页面替换策略,用于管理有限的缓存资源。当缓存满时,LRU算法会优先淘汰最近最少使用的数据。在Java中,我们可以使用数据结构如HashMap和LinkedList来实现LRU缓存。 ...
这个名为“leetcode常用算法java代码”的压缩包文件很可能包含了使用Java语言实现的LeetCode上热门或基础算法问题的解法。让我们深入探讨一下这些常见算法及其在Java中的实现。 1. **排序算法**: - **冒泡排序**...
本资源“经典常用算法 Java和C语言两种实现”聚焦于将这些算法用两种广泛使用的编程语言——Java和C语言进行实现,旨在帮助开发者理解和应用这些基础且重要的算法。 1. **排序算法**: - **冒泡排序**:简单的比较...
这本书的覆盖范围广泛,涉及到算法基础、数据结构、排序算法、查找算法、图论、动态规划等多个重要领域。 在算法基础部分,书中会详细介绍如何用Java实现基本的逻辑控制结构,如循环、条件判断,以及基础的递归思想...
4. **根查找算法**:寻找函数的零点,如二分法、牛顿-拉弗森法等。这些方法在解决方程求解问题时非常有用,Java可以通过迭代实现。 5. **优化算法**:如梯度下降法、牛顿法、遗传算法等,用于找到函数的最小值或...
同时,书中还会讲解如何使用Java实现这些算法。 在字符串处理方面,书中涵盖KMP算法、Rabin-Karp滚动哈希和Manacher's算法等,这些都是处理文本数据和进行模式匹配的常用方法。 最后,本书还会涉及一些算法竞赛和...
这个"Java常用数值算法集"可能包含了以上提到的一些算法的实现,通过学习和研究这些代码,开发者不仅可以加深对数值算法的理解,还能提高解决问题的能力。记得在实际使用时,根据具体需求选择合适的算法和库,并优化...
《Java常用算法手册》分三篇,共13章,分别介绍了算法基础、算法应用和算法面试题。首先介绍了算法概述,然后重点分析了数据结构和基本算法思想;接着,详细讲解了算法在排序、查找、数学计算、数论、历史趣题、游戏...
本资源"数据结构排序查找常用算法实现.zip"提供了一系列常用排序和查找算法的实现,帮助开发者深入理解并掌握这些核心概念。以下是这些算法的详细说明: 1. 冒泡排序(Bubble Sort): 冒泡排序是一种简单的交换...
总的来说,Java实现的中文分词SimHash算法结合了Sanford分词库的分词功能和SimHash的相似度检测,为中文文本的相似度分析提供了一种高效且准确的方法。在实际应用中,这种技术广泛应用于搜索引擎的去重、推荐系统、...
A*(A-star)算法是一种在图形搜索中广泛使用的路径查找算法,它的主要目标是找到从起点到终点的最短路径。A*算法结合了Dijkstra算法的全局最优性和最佳优先搜索的效率,通过引入启发式函数来指导搜索,使得算法能够...
8. **根查找算法**:如二分查找法、牛顿-拉弗森法、Secant方法等,用于寻找方程的实根。这些在物理模型求解、控制理论等领域都有应用。 9. **傅立叶变换**:离散傅立叶变换(DFT)和快速傅立叶变换(FFT)是处理...
8. **根查找算法**:比如二分查找法、Secant方法和Brent方法,用于寻找函数的实根或复根。 9. **数值积分**:如辛普森法则、梯形法则和高斯积分,它们用于估计函数的积分值,特别适合处理不规则分布的数据。 10. *...