数据结构(c语言版)有什么参考书?

Python024

数据结构(c语言版)有什么参考书?,第1张

推荐《数据结构》(c语言版)(清华大学出版社,严蔚敏,吴伟民编著)教材。

《清华大学计算机系列教材:数据结构(C语言版)》的第1章综述数据、数据结构和抽象数据类型等基本概念;第2章至第7章从抽象数据类型的角度,分别讨论线性表、栈、队列、串、数组、广义表、树和二叉树以及图等基本类型的数据结构及其应用。

第8章综合介绍操作系统和编译程序中涉及的动态存储管理的基本技术。

第9章至第11章讨论查找和排序,除了介绍各种实现方法之外,并着重从时间上进行定性或定量的分析和比较;第12章介绍常用的文件结构。

本书可作为计算机类专业或信息类相关专业的本科或专科教材。

数据结构是计算机存储、组织数据的方式。数据结构是指相互之间存在一种或多种特定关系的数据元素的集合。通常情况下,精心选择的数据结构可以带来更高的运行或者存储效率。数据结构往往同高效的检索算法和索引技术有关。

// 二叉树的先序遍历序列: A B C E D F H G I J

// 二叉树的中序遍历序列: E C B H F D J I G A

// 二叉树的后序遍历序列: E C H F J I G D B A

#include "stdio.h"

#include "stdlib.h"

struct tree

{

    char data

    struct tree *left

    struct tree *right

}

typedef struct tree treenode

typedef treenode *btree

btree createbtree(char *data,int pos,int maxPos) //递归创建法

{

    btree newnode

    if(data[pos]==0 || pos>maxPos)

    {

        return NULL

    }

    else

    {

        newnode=(btree)malloc(sizeof(treenode))

        newnode->data=data[pos]

        newnode->left=createbtree(data,2*pos,maxPos)

        newnode->right=createbtree(data,2*pos+1,maxPos)

        return newnode

    }

}

void inorder(btree ptr)

{

    if(ptr!=NULL)

    {

        inorder(ptr->left)

        printf("%C ",ptr->data)

        inorder(ptr->right)

    }

}

void preorder(btree ptr)

{

    if(ptr!=NULL)

    {

        printf("%C ",ptr->data)

        preorder(ptr->left)

        preorder(ptr->right)

    }

}

void postorder(btree ptr)

{

    if(ptr!=NULL)

    {

        postorder(ptr->left)

        postorder(ptr->right)

        printf("%C ",ptr->data)

    }

}

int main()

{

    btree root=NULL

    int i

    char data[64]={0,'A','B',0,'C','D',0,0,

                  'E',0,'F','G',0,0,0,0,

                   0,0,0,0,'H',0,'I',0,0,0,0,0,0,0,0,0,

                   0,0,0,0,0,0,0,0,0,0,0,0,'J',0,0,0,

                   0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0}

    root=createbtree(data,1,63)

    printf("二叉树的顺序存储内容:\n")

    for(i=1i<64i++)

    {

        if(data[i]==0)

        {

            printf("^ ")

        }

        else

        {

            printf("%C ",data[i])

        }

        if(i % 8 == 7) printf("\n")

    }

    printf("\n二叉树的先序遍历序列: ")

    preorder(root)

    printf("\n二叉树的中序遍历序列: ")

    inorder(root)

    printf("\n二叉树的后序遍历序列: ")

    postorder(root)

    printf("\n")

    return 0

}