数据结构CLUB

数据结构网络协作学习平台
  • 图的几个相关操作的实现(以邻接表存储)

    2011-11-13
    typedef struct arcnode

    {int adjvex;

    struct Arcnode *nextarc;

    }Arcnode;

     

    typedef struct vnode

    {char data;

    Arcnode *firstarc;

    }Vnode;

     

    typedef struct

    {Vnode vertices[MAX];

    int vexnum,arcnum;

    }ALGraph;

     

    int locatevex(...
    分类: | Tag:
    WoodyRiver 发表于23:01:00 | 阅读全文 | 评论 0 | 编辑 | 分享 0
  • 图的几个相关操作的实现(以邻接矩阵存储)

    2011-11-13
    typedef struct{
     char vexs[MAX];
     int arcs[MAX][MAX];
     int vexnum,arcnum;
    }MGraph;  // 以邻接矩阵作为图的存储结构

    int Locatevex(MGraph *G,char v)
    { int i;
      for(i=0;ivexnum;++i)
       if(G->vexs[i]==v)  ret...
    分类: | Tag:
    WoodyRiver 发表于22:58:00 | 阅读全文 | 评论 0 | 编辑 | 分享 0
  • 建图算法(邻接矩阵和邻接表两种方法)

    2011-11-13
    1.图的邻接矩阵建图算法

    Status CreateUDG ( MGraph &G ) {

    //采用数组(邻接矩阵)表示法,构造无向图G。

      scanf ( &G. vexnum, &G. arcnum );   

      for ( i = 0; i < G. vexnum; ++i )  scanf ( &G. v...
    分类: | Tag: 图 邻接表 邻接矩阵
    WoodyRiver 发表于22:52:00 | 阅读全文 | 评论 0 | 编辑 | 分享 0
  • 第六章树和二叉树习题 - [作业]

    2011-11-09
     1.假设一棵二叉树的前序遍历序列为EBADCFHGIKJ,中序遍历序列为ABCDEFGHIJK,试画出该二叉树并按后序线索化(用虚线表示线索)。

    2.将下列森林转换为相应的二叉树,并写出此二叉树的中序遍历序列。
     

    3.假定用于通信的电文仅由8个字符C1,C2,C3,C4,C5...
    分类: 作业 | Tag:
    WoodyRiver 发表于22:13:00 | 阅读全文 | 评论 0 | 编辑 | 分享 0
  • 统计二叉树叶子结点个数的程序(参考) - [上机作业]

    2011-11-09
    #include "stdio.h"
    #include "stdlib.h"

    typedef char TElemType;
    typedef struct BiTNode{
        TElemType data;
        struct BiTNode *lchild,*rchild;
    }BitNode,*BiTree;

    void createBitree(BiTree &T)
    {char ch;
    ch=getchar(...
    分类: 上机作业 | Tag:
    WoodyRiver 发表于22:07:00 | 阅读全文 | 评论 0 | 编辑 | 分享 0
  • 中序遍历非递归程序(参考) - [上机作业]

    2011-11-09
    #include "stdio.h"
    #include "stdlib.h"
    #define SqStack_INIT_SIZE 100
    #define SqStackINCREMENT 10
    typedef char TElemType;
    typedef struct BiTNode{
        TElemType data;
        struct BiTNode *lchild,*rchild;
    }BitNode,*BiTree...
    分类: 上机作业 | Tag:
    WoodyRiver 发表于22:06:00 | 阅读全文 | 评论 0 | 编辑 | 分享 0
  • 二叉树遍历算法的应用举例 - [应用举例]

    2011-10-26
    1、统计二叉树中叶子结点的个数。

    void CountLeaf (BiTree T, int &count)

    {

      if ( T ) {

        if ((!T->lchild)&& (!T->rchild))

           count++;

        CountLeaf( T->...
    分类: 应用举例 | Tag: 算法 二叉树遍历 二叉树 递归
    WoodyRiver 发表于21:30:00 | 阅读全文 | 评论 0 | 编辑 | 分享 0
  • 线性结构习题解答 - [思考与练习]

    2011-10-18
    1.删除元素递增排列的链表L中所有值相同的元素。

    int f1(LinkList L) {

     p=L->next;

     while(p->next) {

        q=p->next;

        if(p->data!=q->data)

           p=p->next...
    分类: 思考与练习 | Tag:
    WoodyRiver 发表于21:56:00 | 阅读全文 | 评论 0 | 编辑 | 分享 0
  • 第三章栈和队列 习题 - [作业]

    2011-10-11
    1、写出下列程序段的功能是什么?

     (1)  void demo1(seqstack *s){

            int i;  arr[64];  n=0;

            while (!stackempty(s))   arr[n++]=pop(s);
    ...
    分类: 作业 | Tag: 栈 队列
    WoodyRiver 发表于20:08:00 | 阅读全文 | 评论 0 | 编辑 | 分享 0
  • 图的几个基本操作算法(以邻接表存储) - [算法]

    2009-12-04
    int locatevex(algraph *g,char c)
    {int i;
     for(i=0;i<=g->vexnum;i++)
       if(g->vertices[i].data==c)
         return i;
     return -1;
    }


    int firstadjvex(algraph *g,...
    分类: 算法 | Tag: 图 邻接表 算法
    WoodyRiver 发表于22:03:15 | 阅读全文 | 评论 0 | 编辑 | 分享 0
  • 图的几个基本操作的算法实现(以邻接矩阵为存储结构) - [算法]

    2009-11-16
    typedef struct{
     char vexs[MAX];
     int arcs[MAX][MAX];
     int vexnum,arcnum;
    }MGraph;  // 以邻接矩阵作为图的存储结构

    int Locatevex(MGraph *G,char v)
    { int i;
      for(i=0;i<G->vexnum;++i)
    &nbs...
    分类: 算法 | Tag: 图 基本操作 算法
    WoodyRiver 发表于13:08:22 | 阅读全文 | 评论 0 | 编辑 | 分享 0
  • 图的邻接矩阵和邻接表的建图算法 - [算法]

    2009-11-07
    1.图的邻接矩阵建图算法

    Status CreateUDG ( MGraph &G ) {

    //采用数组(邻接矩阵)表示法,构造无向图G。

      scanf ( &G. vexnum, &G. arcnum );  

      for ( i = 0; i < G. vexnum; ++i )  scanf ( &G...
    分类: 算法 | Tag: 图 邻接矩阵 邻接表 算法
    WoodyRiver 发表于22:06:30 | 阅读全文 | 评论 0 | 编辑 | 分享 0
  • 第六章书面作业 - [作业]

    2009-10-28

    1.假设一棵二叉树的前序遍历序列为EBADCFHGIKJ,中序遍历序列为ABCDEFGHIJK,试画出该二叉树并按后序线索化(用虚线表示线索)。

    分类: 作业 | Tag: 二叉树
    WoodyRiver 发表于21:18:41 | 阅读全文 | 评论 1 | 编辑 | 分享 0
  • 树遍历算法的应用 - [算法]

    2009-10-26
    树遍历算法的应用

    1、求树的深度的算法:

    int TreeDepth(CSTree T) {

      if(!T) return 0;

      else {

         h1 = TreeDepth( T->firstchild );

         h2 ...
    分类: 算法 | Tag: 树的遍历 算法 深度 路径
    WoodyRiver 发表于20:20:56 | 阅读全文 | 评论 0 | 编辑 | 分享 0
  • 二叉树遍历算法的应用举例 - [算法]

    2009-10-20

    1、统计二叉树中叶子结点的个数。

    void CountLeaf (BiTree T, int &count)

    {

      if ( T ) {

        if ((!T->lchild)&& (!T->rchild))

           count...

    分类: 算法 | Tag: 二叉树遍历 算法 应用
    WoodyRiver 发表于23:24:13 | 阅读全文 | 评论 0 | 编辑 | 分享 0
  • 串的首尾匹配算法 - [算法]

    2009-10-09
    串的首尾匹配算法

        先比较模式串的第一个字符,再比较模式串的最后一个字符,最后比较模式串中从第二个到第n-1个字符。

    int Index_FL(SString S, SString T, int pos) {

      sLength = S[0];  tLength = T[0];  i = pos;

      patStart...
    分类: 算法 | Tag: 串 首尾匹配 算法
    WoodyRiver 发表于16:05:56 | 阅读全文 | 评论 0 | 编辑 | 分享 0
  • 第三章练习 - [练习]

    2009-09-27

    1、指出下列程序段的功能是什么?

     (1)  void demo1(seqstack *s){

            int i;  arr[64];  n=0;

            while (!stackempty(s))   a...

    分类: 练习 | Tag: 栈 队列 回文
    WoodyRiver 发表于22:46:00 | 阅读全文 | 评论 0 | 编辑 | 分享 0
  • 栈的应用-表达式求值(后缀式) - [算法]

    2009-09-21
    以下就分"如何按后缀式进行运算"和"如何将原表达式转换成后缀式"两个问题进行讨论。

    n       如何按后缀式进行运算?

    可以用两句话来归纳它的求值规则:"先找运算符,后找操作数。“

       运算过程为:对后缀式从左向右"扫描",遇见操作数则暂时保存,遇见运算符即可进行运算;此时参加运算的两个操作数应该是在它之前刚刚碰到的两个操作数...
    分类: 算法 | Tag: 栈的应用 表达式求值
    WoodyRiver 发表于23:28:06 | 阅读全文 | 评论 0 | 编辑 | 分享 0
  • 栈的应用- 括号匹配的检验算法 - [算法]

    2009-09-19
    算法的设计思想:

    1. 凡出现左括弧,则进栈

    2. 凡出现右括弧,首先检查栈是否空

        若栈空,则表明右括号多了

        否则和栈顶元素比较

                  ...
    分类: 算法 | Tag: 栈的应用 括号匹配
    WoodyRiver 发表于21:14:03 | 阅读全文 | 评论 0 | 编辑 | 分享 0
  • 第二章练习 - [练习]

    2009-09-16
    简述以下算法的功能。

     

    (1) Status A(LinkedList L) { // L 是无表头结点的单链表
        if (L && L->next){
         Q =L; L =L->next; P =L ;
         while ( P->next) P =P->next ;
         P->next =Q; Q->next = N...
    分类: 练习 | Tag: 链表 算法功能
    WoodyRiver 发表于22:58:32 | 阅读全文 | 评论 0 | 编辑 | 分享 0
  • 第一章练习 - [练习]

    2009-09-16
     设n为正整数,求下列算法段的时间复杂度,即T(n)=?

    (1) i=1; k=0;
      while ( i<=n-1) {
      k += 10 * i;
      i++;
      }

     

    (2) k=0;
       for( i=1; i<=n; i++) {
       for (j=i ; j<=n; ...
    分类: 练习 | Tag: 算法时间复杂度
    WoodyRiver 发表于22:49:02 | 阅读全文 | 评论 0 | 编辑 | 分享 0
  • 答疑说明

    2009-09-11

    答疑地点:南校区实验楼五层系办公室(电话:2033957)
    答疑时间:周一至周五上班时间均可
    其他方式:
                  Email- datastructure2008@163.com
               &...

    分类: 练习 | Tag:
    WoodyRiver 发表于09:57:44 | 阅读全文 | 评论 0 | 编辑 | 分享 0
  • 排序(Sorting) - [学习目标]

    2008-12-04
    【学习目标】
      1.理解排序的定义和各种排序方法的特点,并能加以灵活应用。排序方法有不同的分类方法,基于"关键字间的比较"进行排序的方法可以按排序过程所依据的不同原则分为插入排序、交换排序、选择排序、归并排序和计数排序等五类。
      2.掌握各种排序方法的时间复杂度的分析方法。能从"关键字间的比较次数"分析排序算法的平均情况和最坏情况的时间性能。按平均时间复杂度划分,内部排序可分为三类:O (n2) 的简单排序方法,O (n·...
    分类: 学习目标 | Tag:
    WoodyRiver 发表于21:02:39 | 阅读全文 | 评论 0 | 编辑 | 分享 0
  • 查找(Searching) - [学习目标]

    2008-11-28
    【学习目标】
      1.理解"查找表"的结构特点以及各种表示方法的适用性;
      2.熟练掌握以顺序表或有序表表示静态查找表时的查找方法;
      3.熟练掌握二叉查找树的构造和查找方法;
      4.理解二叉平衡树的构造过程;
      5.熟练掌握哈希表的构造方法,深刻理解哈希表与其它结构的表的实质性的差别;
      6.掌握描述查找过程的判定树的构造方法,以及按定义计算各种查找方法在等概率情况下查找成功时的平均查找长度。
    【重...
    分类: 学习目标 | Tag:
    WoodyRiver 发表于22:22:29 | 阅读全文 | 评论 0 | 编辑 | 分享 0
  • 09计算机考研专业课-数据结构考试知识点分析 - [复习要点]

    2008-11-20
    编者按:2009年是计算机专业考研专业基础课首次实行全国统考,面对今年的改变,想报考计算机专业的考生可能对复习的准备有很多的疑问。为了帮助考生正确的做好准备工作,学赛网研究生院特访问了我国著名的计算机教育专家、湖南师范大学计算机软件与理论/计算机应用技术硕士点专业课试题命题人张友生博士,请张博士对考试大纲进行全面的解析。本文为大纲解析的第二篇:数据结构知识点分析。
        在计算机考研专业基础课统考科目中,一共考查数据结构、操作系统、计算机组成原理、计算机网络...
    分类: 复习要点 | Tag:
    WoodyRiver 发表于15:58:42 | 阅读全文 | 评论 0 | 编辑 | 分享 0
  • 以邻接表方式建图算法 - [算法]

    2008-11-17
    Status Build_AdjList(ALGraph &G)//输入有向图的顶点数,边数,顶点信息和边的信息建立邻接表
    {InitALGraph(G);
      scanf("%d",&v);
      if(v<0)   return ERROR; //顶点数不能为负
      G.vexnum=v;
      scanf(&...
    分类: 算法 | Tag:
    WoodyRiver 发表于22:31:45 | 阅读全文 | 评论 0 | 编辑 | 分享 0
  • 克鲁斯卡尔算法Kruskal - [算法]

    2008-11-11
    typedef struct        {   int u;     /*边的起始顶点*/            int v;     /*边的终止顶点*/        ...
    分类: 算法 | Tag:
    WoodyRiver 发表于21:54:23 | 阅读全文 | 评论 0 | 编辑 | 分享 0
  • 图(Graph) - [学习目标]

    2008-11-05
    【学习目标】
      1.领会图的类型定义。
      2.熟悉图的各种存储结构及其构造算法,了解各种存储结构的特点及其选用原则。
      3.熟练掌握图的两种遍历算法。
      4.理解各种图的应用问题的算法。
    【重点和难点】
      图的应用极为广泛,而且图的各种应用问题的算法都比较经典,因此本章重点在于理解各种图的算法及其应用场合。
    【知识点】
      图的类型定义、图的存储表示、图的深度优先搜索遍历和图的广度优先搜索遍历、最小生成树、拓扑...
    分类: 学习目标 | Tag:
    WoodyRiver 发表于22:24:07 | 阅读全文 | 评论 0 | 编辑 | 分享 0
  • 稀疏矩阵的快速转置程序 - [练习]

    2008-10-29
    #define P 4
    #define N 5
    #define MAXSIZE 10
    typedef struct
      { int i,j;
        int  e;
      }Triple;
    typedef struct
      { Triple data[MAXSIZE+1];
        int mu,nu,tu;...
    分类: 练习 | Tag:
    WoodyRiver 发表于20:28:40 | 阅读全文 | 评论 2 | 编辑 | 分享 0
  • 串的模式匹配程序(BF算法) - [练习]

    2008-10-29

    #define M 250
    #include "stdio.h"
    #include  "string.h"
    typedef  char   SString;
    int Index (SString S[M],SString T[M],int pos,int m,int n)
    { int i,j;
      i=pos-1;
      j=0;...

    分类: 练习 | Tag:
    WoodyRiver 发表于20:26:18 | 阅读全文 | 评论 0 | 编辑 | 分享 0
共2页 1 2 下一页 最后一页

个人资料

WoodyRiver

日历

搜索

文章分类

  • 概念[1]
  • 术语[0]
  • 算法[14]
  • 练习[5]
  • 作业[3]
  • 课外扩展[2]
  • 学习目标[8]
  • 应用举例[2]
  • 思考与练习[3]
  • 复习要点[1]
  • 上机作业[2]

Tag

  • 算法[13]
  • 图[8]
  • 二叉树[6]
  • 二叉树遍历[6]
  • 邻接表[5]
More..

最新日志

  • 图的几个相关操作的实现(以邻接表存储)
  • 图的几个相关操作的实现(以邻接矩阵存储)
  • 建图算法(邻接矩阵和邻接表两种方法)
  • 第六章树和二叉树习题
  • 统计二叉树叶子结点个数的程序(参考)
  • 中序遍历非递归程序(参考)
  • 二叉树遍历算法的应用举例
  • 线性结构习题解答
  • 第三章栈和队列 习题
  • 图的几个基本操作算法(以邻接表存储)
全部日志>>

最新评论

  • zzz:图片挂了。。。
  • 07:老师能不能找些正规的练习和考研有关的...
  • ~~:老师,主要程序后面能不能加上中文解释...
  • idjf:#include"stdlib.h"...
  • Jed:程序设计=数据结构+算法...

链接

  • 绿茶的专栏
  • 花开花落
  • 数据结构与算法分析(C#)
  • KnowMore
  • Bell的个人空间

存档

  • 2011 [9]
  • 2009 [13]
  • 2008 [20]
  • 访问统计:
  • RSS 什么是RSS?
    用IM提醒我内容更新
    订阅到QQ邮箱
    订阅到鲜果阅读器
    订阅到Google阅读器
    订阅到抓虾阅读器
  • 《城客》第四期:创意之城
    博客大巴
    博客大巴使用指南
    博客大巴模板中心
    免费注册博客大巴
    一键博客搬家工具
    中文互动杂志城客
Copyright © 2002-2012 BlogBus.com, All Rights Reserved. 博客大巴 版权所有
博客大巴模板设计:飞鸟ASKA | 作者: 饭团