zoukankan      html  css  js  c++  java
  • 数据结构(1)有序表查找

     有序表查找

    	/*  主函数  */
    	public class OrderTableSearch {
    		public static void main(String[] args) {
    			int [] a= {0,1,16,24,35,47,59,62,73,88,99};	
    			System.out.println(FibonacciSearch(a, 10, 88));
    			System.out.println(InsertKeySearch(a, 10, 88));
    			System.out.println(BinarySearch(a, 10, 88));
    		}

    一、折半查找 

    		/* 折半查找  */
    		/* 输出:9 */
    		static int BinarySearch(int [] a, int n, int key){
    			int low, high, mid;
    			low = 0;
    			high = n;
    			while(low <= high){
    				mid = (low + high) / 2; /* 折半  */
    				if (key < a[mid]){
    					high = mid - 1;
    				}
    				else if (key > a[mid]){
    					low = mid + 1;
    				}
    				else 
    					return mid;
    			}
    			return 0;
    		}

    二、插值查找 

    		/* 插值排序 */
    		/* 输出:9 */
    		static int InsertKeySearch(int [] a, int n, int key){
    			int low, high, mid;
    			low = 0;
    			high = n;
    			while(low <= high){
    				/* 插值查找的计算公式 */
    				mid = low + (high - low)*
    						(key - a[low])/(a[high] - a[low]);
    				if (key < a[mid]){
    					high = mid - 1;
    				}
    				else if (key > a[mid]){
    					low = mid + 1;
    				}
    				else 
    					return mid;
    			}
    			return 0;
    		}

    三、斐波那契查找 

    		/* 斐波那契排序 */
    		/* 输出:9 */
    		static int FibonacciSearch(int [] a, int n, int key){
    			int [] F = {0,1,1,2,3,5,8,13,21,34};
    			int low, high, mid, i, k;
    			low = 1;
    			high = n;
    			k = 0;
    			while (n > F[k]-1) /* 计算n位于斐波那契数列的位置 */
    				k++;
    			
    			while (low <= high) {
    				mid = low + F[k-1] -1;
    				if (key < a[mid]){
    					high = mid - 1;
    					k = k - 1;
    				}
    				else if (key > a[mid]){
    					low = mid + 1;
    					k = k - 2;
    				}
    				else {
    					if (mid <= n)
    						return mid;
    					else
    						return n;
    				}
    			}
    			return 0;
    		}
    

    四、三种查找方法的比较

      平均性能:斐波那契>折半>插值,因为折半查找是加法与除法的运算,插值为四则运算,斐波那契加减运算。

      

  • 相关阅读:
    2.9数据-paddlepaddle数据集wmt16
    2.8数据-paddlepaddle数据集uci_housing
    2.6数据-paddlepaddle数据集movielens
    2.5数据-paddlepaddle数据集imikolov
    2.4数据-paddlepaddle数据集imdb
    2.3数据-paddlepaddle数据集Conll05
    在android程序中怎么执行ifconfig命令来修改android 的ip地址,
    VMware 11安装Mac OS X 10.10 及安装Mac Vmware Tools.
    xcode7 如何真机测试
    海子
  • 原文地址:https://www.cnblogs.com/danbing/p/5128089.html
Copyright © 2011-2022 走看看