当前位置: 首页 > news >正文

5东莞网站建设云服务器可以用来做网站么

5东莞网站建设,云服务器可以用来做网站么,云南省玉溪市建设局官方网站,学校网站建设及使用档案引入: 问题1: n个节点的二叉树,用二叉链表存储,问在这个二叉链表中一共有 __个指针域? 其中,有 __个指针域不为NULL,__个指针域为NULL? 答:2n n-1 n1 在二叉链表中&#xf…

引入:

问题1:

n个节点的二叉树,用二叉链表存储,问在这个二叉链表中一共有 __个指针域?
其中,有 __个指针域不为NULL,__个指针域为NULL?

答:2n        n-1        n+1

在二叉链表中,每一个结点都有左右两个指针域,那么有n个结点,则有n个指针域

每一个结点可以有多个孩子,这并不利于我们判断非空指针域个数,所以我们可以考虑每个结点的父亲,因为一个结点的父亲结点有且仅有一个(根节点没有父亲),因此非空指针域为n-1,那么剩下的n+1个指针为空指针

同时这也说明,存在这n+1的指针域空间的浪费

问题2:
中序遍历序列中,E的前驱和后继节点分别是?



一种思路是进行中序遍历(BDCAEHGKF )保存下中序遍历序列 然后在序列中找某个节点前驱or后继
这里我们还可以采用另一种思路,进行线索化,不需要遍历 直接在树上找答案

那么什么是线索化?

线索化是让一个结点的左指针指向其前驱结点,让右指针指向其后继结点。这种指向前驱和后继的指针称为线索。将一棵普通二叉树以某种次序遍历,并添加线索的过程称为线索化

分类

线索化可以分为先序线索化、中序线索化和后序线索化

 例子:中序线索化

在中序遍历的源代码的基础上添加线索,即将之前遍历的visit函数由输出操作改为添加线索操作,引入一个pre指针,记录刚刚访问过的节点。假设现在访问x节点,此时 x的前驱是pre pre的后继是x。如果x->left==NULL x->left=pre;;给x添加前驱线索;如果pre->right==NULL pre->right=x:给pre添加后继线索。在访问完x后 pre=x

中序遍历寻找前驱:

情况1:x-> |flag==1,x的左指针域是线索,x->left就是前驱
情况2:x->lflag==0,x的左指针域是孩子,x的左子树中最靠右的节点是前驱

找节点x的中序遍历后继:
情况1:x->rflag==1,x的右指针域是线索,x->rflag就是后继
情况2:x->rFLAG==0,x的右指针域是孩子, 就是后继下右子树中最靠左的节点就是后继

代码

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>//二叉链表节点结构
typedef struct BTNode {char data;struct BTNode* left;//保存左孩子地址int lflag;//=0 孩子  =1线索 struct BTNode* right;//保存右孩子地址 int rflag;
}BTNode, * BTree;
BTNode* pre = NULL;
BTree initBTree(char root)
{BTNode* r = (BTNode*)malloc(sizeof(BTNode));if (r == NULL){printf("空间分配失败\n");return NULL;}r->data = root;r->left = r->right = NULL;r->lflag = r->rflag = 0;return r;
}
BTNode* find(BTree r, char fx)
{if (r == NULL || r->data == fx){return r;}if (r->left != NULL && r->lflag == 0){BTNode* ans = find(r->left, fx);if (ans != NULL && ans->data == fx){return ans;}}if (r->right != NULL && r->rflag == 0){BTNode* ans = find(r->right, fx);if (ans != NULL && ans->data == fx){return ans;}}return NULL;
}BTree insert(BTree r, char x, char fx, int flag)
{BTNode* f = find(r, fx);if (f == NULL){printf("父亲节点不存在,不能插入\n");}else{BTNode* s = (BTNode*)malloc(sizeof(BTNode));//判断s==NULLs->data = x;s->left = s->right = NULL;s->lflag = s->rflag = 0;if (flag == 0){f->left = s;}else {f->right = s;}}return r;
}
//添加线索 
void visit(BTNode* x)
{//pre是x的前驱if (x->left == NULL){x->left = pre;x->lflag = 1;}//x是pre的后继if (pre != NULL && pre->right == NULL){pre->right = x;pre->rflag = 1;}pre = x;
}//对以r为根的树进行先序遍历 
void PerOrder(BTree r)//先序遍历
{if (r == NULL)//空树不需要遍历 {return;}visit(r);//访问根节点if (r->lflag == 0)PerOrder(r->left);//对左子树进行先序遍历PerOrder(r->right);//对右子树进行先序遍历
}
//对以r为根的树进行中序遍历 
void InOrder(BTree r)//中序遍历
{if (r == NULL)//空树不需要遍历 {return;}InOrder(r->left);//对左子树进行中序遍历visit(r);//访问根节点InOrder(r->right);//对右子树进行中序遍历
}
//对以r为根的树进行后序遍历 
void PostOrder(BTree r)//后序遍历
{if (r == NULL)//空树不需要遍历 {return;}PostOrder(r->left);//对左子树进行后序遍历PostOrder(r->right);//对右子树进行后序遍历visit(r);//访问根节点
}
BTNode* find_pre(BTree r, BTNode* p)
{if (p->lflag == 1){return p->left;}else{BTNode* q = p->left;while (q->right != NULL && q->rflag == 0){q = q->right;}return q;}
}
BTNode* find_post(BTree r, BTNode* p)
{if (p->rflag == 1){return p->right;}else{BTNode* q = p->right;//如果p是中序遍历序列的最后一个节点,q是NULL;if (q == NULL){return q;}while (q->left != NULL && q->lflag == 0){q = q->left;}return q;}
}
int main()
{int n;int flag;//=0 左  =1右孩子 BTree r = NULL;char root;scanf("%d", &n);getchar();scanf("%c", &root);r = initBTree(root);char x, fx;for (int i = 1; i <= n - 1; i++){getchar();scanf("%c %c %d", &x, &fx, &flag);r = insert(r, x, fx, flag);}//先序遍历//PerOrder(r); //中序遍历sInOrder(r);getchar();scanf("%c", &x);BTNode* p = find(r, x);//找前驱BTNode* ppre = find_pre(r, p);if (ppre == NULL){printf("中序遍历前驱不存在\n");}else {printf("%c\n", ppre->data);}//找后继 BTNode* post = find_post(r, p);if (post == NULL){printf("中序遍历后继不存在\n");}else {printf("%c\n", post->data);}//后序遍历//PostOrder(r); return 0;
}

http://www.yayakq.cn/news/459315/

相关文章:

  • 有风险的网站网上购物系统的设计与实现论文
  • 培训网站哪个最好的网站开发技术支持与保障
  • 做快手网站hao123网站用什么程序做的
  • 什么大的网站是帝国cms做的wordpress module破解
  • 汕头网站建设stqhcx广告图片
  • 腾讯云主机能给几个网站备案手表网站背景素材
  • 基于html5的旅游网站的设计与实现网页截图快捷键可拉动
  • 聊城有什么网站制作公司xampp wordpress安装
  • 济南企业免费建站网站毕业设计选题
  • 大宗商品价格查询网站自己做网站翻译服务器 - 添加网站
  • 陵水网站建设报价怎样优化网站关键词
  • idea 做网站登录企业网站建设服务公司
  • 漯河网站关键词优化wordpress适合中文主题
  • 宜昌做网站优化海南新闻在线中心
  • 吉林省长春网站建设北京海华城市建设学校网站
  • 关于网站建设的介绍网站推广外包公司哪家好
  • 小说网站wordpress什么网站能看到专业的做面包视频
  • 网站的视频怎么下载wordpress拼音插件
  • 建设网站需要注意什么问题微网站用什么软件做
  • 高端网站建设郑州一级 做爰免费网站
  • 网站首页弹出图片哔哩哔哩视频大全
  • 网站都有什么费用呼和浩特网站建设哪家最便宜?
  • 华强北设计网站建设山西做网站的公司
  • 网站建设业务的途径的体会wordpress 谷歌搜索
  • 大屏手机网站企业管理咨询上班好吗
  • 管理咨询师报考条件2022年googleseo優化
  • 广州市建设局官方网站哪里可以找到制作网站的公司
  • 网站建设在360属于什么类目用动态和静态设计一个网站
  • 乐清微网站建设深圳网站建设代理商
  • 网站栏目内链怎么做html进入网页自动播放音乐