关闭

查找(一)静态表查找

标签: 静态查找
715人阅读 评论(0) 收藏 举报
分类:

静态表查找包括:顺序表查找、有序表查找、静态树表查找、索引表查找
具体原理这里不叙述,详见严蔚敏《数据结构》。

1、顺序表查找

//SequenceTableSearch.c

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

typedef char KeyType;//定义关键字类型
typedef struct{
    KeyType key;
}ElemType;//定义元素类型

//定义静态查找表的顺序存储结构
typedef struct {
    ElemType *elem;
    int length;
}SSTable;

//此函数在顺序表中顺序查找关键字等于key的数据元素。
int Search_Seq(SSTable ST, KeyType key){
    //若找到,则函数值为该元素在表中的位置,否则返回0
    int i;

    ST.elem[0].key = key;//第0个元素做哨兵
    for (i = ST.length; strcmp(ST.elem[i].key, key); i++) ;//从后往前找

    return i;
}

2、有序表查找

有序表查找可以用多种查找方法,包括:折半查找、斐波那契查找、插值查找
折半查找最为常见。

//BinarySearch.c

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

typedef char KeyType;//定义关键字类型
typedef struct{
    KeyType key;
}ElemType;//定义元素类型

//定义静态查找表的顺序存储结构
typedef struct {
    ElemType *elem;
    int length;
}SSTable;

//此函数在有序表ST中折半查找其关键字等于key的数据元素
int Search_Bin(SSTable ST, KeyType key){
    //若找到,函数返回该元素在表中的位置。否则返回0
    int low = 1,high=ST.length,mid;
    while (low<=high){
        mid = (low + high) / 2;
        if (!strcmp(key,ST.elem[mid].key)){
            return mid;
        }else if(strcmp(key,ST.elem[mid].key)<0){
            high = mid - 1;
        }else{
            low = mid + 1;
        }
    }

    return 0;
}

3、静态树表查找

静态树表可以是:静态最优查找树(Static Optimal Search Tree)、次优查找树(Nearly Optimal Search Tree)
这里给出次优查找树的建立。

//CreateSecondOptimalBiTree.c

#include <stdio.h>
#include <stdlib.h>
#include <math.h>


typedef char KeyType;//定义关键字类型
typedef struct{
    KeyType key;
}ElemType;//定义元素类型
typedef struct BiTNode{
    ElemType data;
    struct BiTNode *lchild, *rchild;
}BiTNode, *BiTree;

//data field
int i;
int min;
int dw;

//(读此代码必须看教科书算法原理描述)

//此函数创建一个次优查找树
void CreateSecondOptimalBiTree(BiTree T, ElemType R[], float sw[], int low, int high){
    //由有序表R[low...high]及其累计权值表sw(其中sw[0]==0)递归构造次优查找树

    i = low;
    min = abs(sw[high] - sw[low]);
    dw = sw[high] + sw[low - 1];

    for (int j = low+1; j <=high; j++){//选择最小的△Pi值
        if (abs(dw-sw[j]-sw[j-1])<min){
            i = j;
            min = abs(dw - sw[j] - sw[j - 1]);
        }
    }

    T = (BiTree)malloc(sizeof(BiTNode));
    T->data = R[i];//生成结点(第一次生成根)
    if (i == low) T->lchild = NULL;//左子树空
    else CreateSecondOptimalBiTree(T->lchild, R, sw, low, i - 1);//构造左子树
    if (i == high) T->rchild = NULL;//右子树空
    else CreateSecondOptimalBiTree(T->rchild, R, sw, i + 1, high);//构造右子树

}

4、索引表查找

详见教材。

1
0
查看评论

静态查找表

【问题描述】静态查找表可以有不同的表示方法,在不同的表示方法中,实现查找操作的方法也不同。对静态查找表可以用顺序表或线性链表进行表示,也可组织成有序的顺序表,或者是索引顺序表,相应的查找方法可采用顺序查找方法、折半查找方法和索引顺序查找的方法。设计一个有关静态查找表的建立、查找等基本操作的演示程序,...
  • sdp
  • sdp
  • 2006-09-13 09:29
  • 2999

静态查找静态树表

一、基本思想静态树表为的是解决查找概率不等的记录。一般情况下,我们都是默认各个记录等概率查找的,但是有些记录可能不是等概率的。我们可能会首先搜索一些概率大的记录。 二、构造过程次优查找树和最优查找树的查找性能仅差1%-2%,而构造最优查找树花费时间代价较高。现构造一棵二叉树,使得二叉树的带权内的路...
  • qq_16234613
  • qq_16234613
  • 2016-09-29 13:34
  • 1508

数据结构学习笔记 --- 查找(静态查找表)

1. 引言  本文主要讲解静态查找表。静态查找表在查找的过程中不改变表的状态——不插不删。他适合用于不变动或不常变动的表的查 找。如高考成绩表、本单位职工信息表等。下面分别介绍顺序查找,有序表的折半查找,静态树表的查找。 2....
  • whz_zb
  • whz_zb
  • 2012-03-10 11:43
  • 3717

查找(1)--静态查找

查找分为两种:             静态查找: 只查找,不改变数据元素集内的数据元素;             动态查找:既查找,又改变(增减)集合内的数据元素。 静...
  • u013360022
  • u013360022
  • 2014-02-21 13:54
  • 1361

静态表查找--顺序表的查找(有序)--折半查找

静态查找表在查找的过程中不改变表的状态---不插入也不删除,适合不变动或者不经常变动的查找,顺序表可以使有序的也可以是无序的,如果是有序的可以使用折半查找,每查找一次,就把范围缩小一半,如果是无序的就只能从表的一端开始逐一查找了。 本文先用Create_Seq(SSTable &ST,El...
  • u011456016
  • u011456016
  • 2015-12-09 16:04
  • 2512

静态查找表与动态查找表

一、静态查找表 1.顺序表查找 顺序查找(Sequential Search)又称为线性查找,是一种最简单的查找方法。 查找过程如下: 从线性表的一端开始顺序扫描线性表,依次将扫描到的结点关键字和给定值进行比较。 若当前扫描到的结点关键字与给定值相等,则查找成功; 若扫描结束后,...
  • zhangkongzhongyun
  • zhangkongzhongyun
  • 2014-03-24 15:06
  • 6768

查找(1)--静态查找

作者:fan_rockrock 链接:http://blog.csdn.net/wust__wangfan/article/details/19563433 查找分为两种:             静态查找: 只...
  • Hello_World_LVLcoder
  • Hello_World_LVLcoder
  • 2017-05-31 21:47
  • 174

查找(一)静态表查找

静态表查找包括:顺序表查找、有序表查找、静态树表查找、索引表查找 具体原理这里不叙述,详见严蔚敏《数据结构》。1、顺序表查找//SequenceTableSearch.c#include <stdio.h> #include <stdlib.h> #include <...
  • qq_16912257
  • qq_16912257
  • 2015-07-06 21:47
  • 715

顺序查找--二分查找--静态树表的查找--分块查找

一、顺序表的顺序查找 1、顺序查找 由表的一端开始,逐个检测每个记录是不是要查的记录。找到则查找成功,一直找到另一端还没找到则失败。 1)顺序存储结构下的顺序查找 #include using namespace std; typedef int KeyType; struct RecType ...
  • qq_22238021
  • qq_22238021
  • 2017-10-13 13:46
  • 425

算法学习之查找算法:静态查找表(1)顺序表查找

引言:         查找表一般
  • To_Be_IT_1
  • To_Be_IT_1
  • 2014-09-22 06:44
  • 1881
    个人资料
    • 访问:191975次
    • 积分:4814
    • 等级:
    • 排名:第7079名
    • 原创:290篇
    • 转载:39篇
    • 译文:0篇
    • 评论:9条
    最新评论