2014年软考程序员-常考知识点复习笔记【第二章】

51CTO学院,在软考备考季特别整理了"2014年软考程序员-常考知识点复习笔记【汇总篇】",帮助各位学院顺利过关!更多软件水平考试辅导及试题,请关注51CTO学院-软考分类吧

查看汇总:2014年软考程序员-常考知识点复习笔记【汇总篇】 

  二叉树三种遍历的非递归算法(背诵版)

  1.先序遍历非递归算法

  #define maxsize 100

  typedef struct

  {

  Bitree Elem[maxsize];

  int top;

  }SqStack;

  void PreOrderUnrec(Bitree t)

  {

  SqStack s;

  StackInit(s);

  p=t;

  while (p!=null || !StackEmpty(s))

  {

  while (p!=null) //遍历左子树

  {

  visite(p->data);

  push(s,p);

  p=p->lchild;

  }//endwhile

  if (!StackEmpty(s)) //通过下一次循环中的内嵌while实现右子树遍历

  {

  p=pop(s);

  p=p->rchild;

  }//endif

  }//endwhile

  }//PreOrderUnrec

  2.中序遍历非递归算法

  #define maxsize 100

  typedef struct

  {

  Bitree Elem[maxsize];

  int top;

  }SqStack;

  void InOrderUnrec(Bitree t)

  {

  SqStack s;

  StackInit(s);

  p=t;

  while (p!=null || !StackEmpty(s))

  {

  while (p!=null) //遍历左子树

  {

  push(s,p);

  p=p->lchild;

  }//endwhile

  if (!StackEmpty(s))

  {

  p=pop(s);

  visite(p->data); //访问根结点

  p=p->rchild; //通过下一次循环实现右子树遍历

  }//endif

  }//endwhile

  }//InOrderUnrec

  3.后序遍历非递归算法

  #define maxsize 100

  typedef enum{L,R} tagtype;

  typedef struct

  {

  Bitree ptr;

  tagtype tag;

  }stacknode;

  typedef struct

  {

  stacknode Elem[maxsize];

  int top;

  }SqStack;

  //后序遍历

  void PostOrderUnrec(Bitree t)

  {

  SqStack s;

  stacknode x;

  StackInit(s);

  p=t;

  do

  {

  while (p!=null) //遍历左子树

  {

  x.ptr = p;

  x.tag = L; //标记为左子树

  push(s,x);

  p=p->lchild;

  }

  while (!StackEmpty(s) &&s.Elem[s.top].tag==R)

  {

  x = pop(s);

  p = x.ptr;

  visite(p->data); //tag为R,表示右子树访问完毕,故访问根结点

  }

  if (!StackEmpty(s))

  {

  s.Elem[s.top].tag =R; //遍历右子树

  p=s.Elem[s.top].ptr->rchild;

  }

  }while (!StackEmpty(s));

  }//PostOrderUnrec

  4.层次遍历算法

  // 二叉树的数据结构

  structBinaryTree

  {

  int value; // 不写模板了,暂时用整形代替节点的数据类型

  BinaryTree *left;

  BinaryTree *right;

  };

  BinaryTree*root; // 已知二叉树的根节点

  //层次遍历

  voidLevel( const BinaryTree *root )

  {

  Queue *buf = new Queue(); // 定义一个空队列,假设此队列的节点数据类型也是整形的

  BinaryTree t; // 一个临时变量

  buf.push_back(root); //令根节点入队

  while( buf.empty == false ) // 当队列不为空

  {

  p = buf.front(); // 取出队列的第一个元素

  cout



精品文章推荐:

备战2014软考!精品视频教程推荐(综合复习+经验分享+考前冲刺)

2014年计算机软考《网络管理》知识点【汇总篇】

2014年软考网络管理员考试练习题及答案【汇总篇】

2014年软考程序员-笔试-考前练习试题【汇总篇】


软考类在线视频教程,请点击:

http://edu.51cto.com/course/courseList/id-44.html



2014年软考程序员-常考知识点复习笔记【第二章】

时间: 2024-10-07 17:11:59

2014年软考程序员-常考知识点复习笔记【第二章】的相关文章

2014年软考程序员-常考知识点复习笔记【汇总篇】

51CTO学院,在软考备考季特别整理了"2014年软考程序员-常考知识点复习笔记[汇总篇]",帮助各位学院顺利过关!更多软件水平考试辅导及试题,请关注51CTO学院-软考分类吧! 2014年软考程序员常考知识点复习笔记汇总 1 2014年软考程序员常考知识点复习笔记第一章 查看详情 2 2014年软考程序员常考知识点复习笔记第二章 查看详情 3 2014年软考程序员常考知识点复习笔记第三章 查看详情 4 2014年软考程序员常考知识点复习笔记第四章 查看详情 5 2014年软考程序员常

2014年软考程序员-常考知识点复习笔记【第一章】

51CTO学院,在软考备考季特别整理了"2014年软考程序员-常考知识点复习笔记[汇总篇]",帮助各位学院顺利过关!更多软件水平考试辅导及试题,请关注51CTO学院-软考分类吧! 查看汇总:2014年软考程序员-常考知识点复习笔记[汇总篇]  常考基础知识必会 A. 排序:排序有几种,各种排序的比较,哪些排序是稳定的,快排的算法; B. 查找:哈希查找.二叉树查找.折半查找的对比,哈希映射和哈希表的区别? C. 链表和数组的区别,在什么情况下用链表什么情况下用数组? D. 栈和队列的区

2014年软考程序员-常考知识点复习笔记【第三章】

51CTO学院,在软考备考季特别整理了"2014年软考程序员-常考知识点复习笔记[汇总篇]",帮助各位学院顺利过关!更多软件水平考试辅导及试题,请关注51CTO学院-软考分类吧! 查看汇总:2014年软考程序员-常考知识点复习笔记[汇总篇]  2.线性表 (1) 性表的链式存储方式及以下几种常用链表的特点和运算:单链表.循环链表,双向链表,双向循环链表. (2)单链表的归并算法.循环链表的归并算法.双向链表及双向循环链表的插入和删除算法等都是较为常见的考查方式. (3)单链表中设置头指

2014年软考程序员-常考知识点复习笔记【第四章】

51CTO学院,在软考备考季特别整理了"2014年软考程序员-常考知识点复习笔记[汇总篇]",帮助各位学院顺利过关!更多软件水平考试辅导及试题,请关注51CTO学院-软考分类吧! 查看汇总:2014年软考程序员-常考知识点复习笔记[汇总篇]  4.串 串一章需要攻破的主要堡垒有: 1. 串的基本概念,串与线性表的关系(串是其元素均为字符型数据的特殊线性表),空串与空格串的区别,串相等的条件; 2. 串的基本操作,以及这些基本函数的使用,包括:取子串,串连接,串替换,求串长等等.运用串的

2014年软考程序员-常考知识点复习笔记【第五章】

51CTO学院,在软考备考季特别整理了"2014年软考程序员-常考知识点复习笔记[汇总篇]",帮助各位学院顺利过关!更多软件水平考试辅导及试题,请关注51CTO学院-软考分类吧! 查看汇总:2014年软考程序员-常考知识点复习笔记[汇总篇]  内部排序 考查你对书本上的各种排序算法及其思想以及其优缺点和性能指标(时间复杂度)能否了如指掌. 排序方法分类有:插入.选择.交换.归并.计数等五种排序方法. (1)插入排序中又可分为:直接插入.折半插入.2路插入(?).希尔排序.这几种插入排序

2014年软考程序员-常考知识点复习笔记【第六章】

51CTO学院,在软考备考季特别整理了"2014年软考程序员-常考知识点复习笔记[汇总篇]",帮助各位学院顺利过关!更多软件水平考试辅导及试题,请关注51CTO学院-软考分类吧! 查看汇总:2014年软考程序员-常考知识点复习笔记[汇总篇]  OSI模型7层结构,TCP/IP模型结构? osi参考模型 osi参考模型中的数据封装过程 下面的图表试图显示不同的TCP/IP和其他的协议在最初OSI模型中的位置: 7应用层例如HTTP.SMTP.SNMP.FTP.Telnet.SIP.SSH

2014年软考程序员-常考知识点复习笔记【第七章】

51CTO学院,在软考备考季特别整理了"2014年软考程序员-常考知识点复习笔记[汇总篇]",帮助各位学院顺利过关!更多软件水平考试辅导及试题,请关注51CTO学院-软考分类吧! 查看汇总:2014年软考程序员-常考知识点复习笔记[汇总篇]  数组和链表的优缺点 数组,在内存上给出了连续的空间.链表,内存地址上可以是不连续的,每个链表的节点包括原来的内存和下一个节点的信息(单向的一个,双向链表的话,会有两个). 数组优于链表的: A. 内存空间占用的少,因为链表节点会附加上一块或两块下

2014年软考程序员-常考知识点复习笔记【第八章】

51CTO学院,在软考备考季特别整理了"2014年软考程序员-常考知识点复习笔记[汇总篇]",帮助各位学院顺利过关!更多软件水平考试辅导及试题,请关注51CTO学院-软考分类吧! 查看汇总:2014年软考程序员-常考知识点复习笔记[汇总篇]  C++操作符优先级: 记忆方法: 去掉一个最高的,去掉一个最低的,剩下的是一.二.三.赋值;双目运算符中,顺序为算术.关系和逻辑,移位和逻辑位插入其中. --摘自<C语言程序设计实用问答> 问题:如何记住运算符的15种优先级和结合性?

2014年软考程序员-常考知识点复习笔记【第九章】

51CTO学院,在软考备考季特别整理了"2014年软考程序员-常考知识点复习笔记[汇总篇]",帮助各位学院顺利过关!更多软件水平考试辅导及试题,请关注51CTO学院-软考分类吧! 查看汇总:2014年软考程序员-常考知识点复习笔记[汇总篇]  B树.B-树.B+树.B*树.红黑树和trie树 (1)B树:即二叉搜索树. 1.所有非叶子结点至多拥有两个儿子(Left和Right); 2.所有结点各存储一个关键字; 3.非叶子结点的左指针指向小于其关键字的子树,右指针指向大于其关键字的子树