- 浏览: 736616 次
- 性别:
- 来自: 嘉兴
文章分类
- 全部博客 (386)
- Struts1.1 (2)
- Database (18)
- Core Java (15)
- Log4j (4)
- SSH (0)
- Dao (1)
- Architecture Design (1)
- References (2)
- Eclipse&MyEclipse (10)
- Hibernate (7)
- Spring (8)
- JavaMail (1)
- Data Structure And Algorithm (48)
- Struts 2 (2)
- SSI (1)
- SSL (2)
- JSTL (1)
- EJB3 (2)
- NET (2)
- XML (2)
- Components (2)
- Ant (3)
- Multi Thread (1)
- Performance Monitoring (1)
- Web Server (17)
- Oracle (1)
- jQuery (8)
- Regular Expression (1)
- Weblogic (1)
- Exception (1)
- Security (2)
- File Manipulation (1)
- JavaScript (12)
- JVM (2)
- HTML&DIV&CSS (4)
- Android (10)
- Beyond GFW (0)
- Business (0)
- SVN (6)
- 虚拟主机 (1)
- Virtual Host (3)
- My mentality (5)
- OS (15)
- ISPMP (3)
- Magento (5)
- Jsoup&HttpClient (7)
- LINUX (9)
- Database Design (0)
- Power Designer (1)
- TaobaoOpenPlatform (2)
- C/C++ (3)
- Maven (11)
- Quartz (1)
- Load Balance (1)
- Zabbix (4)
- Product&Business (1)
- Pay Interface (1)
- Tomcat (2)
- Redis (1)
- 集群 (1)
- Session (1)
- 共享Session (1)
- Jedis (1)
- jenkins (1)
- 持续集成 (1)
- Web前端 (1)
最新评论
-
aqq331325797:
特意注册账号上来说一句。牛逼!
swagger2.2.2 与 spring cloud feign冲突 -
KitGavinx:
跨顶级域名怎么保持sessionid一致?
Tomcat7集群共享Session 基于redis进行统一管理 -
jaychang:
dujianqiao 写道HI ,能否给一个完整的demo 啊 ...
淘宝订单同步方案 - 丢单终结者 -
GGGGeek:
找了一会儿,感觉mybatis应该没有这种操作,直到发现博主的 ...
mybatis collection list string -
dujianqiao:
HI ,能否给一个完整的demo 啊 ?
淘宝订单同步方案 - 丢单终结者
#include<iostream> using namespace std; #define MAX 1500 //二叉树定义 typedef struct BiTreeNode{ char data; BiTreeNode *lChild; BiTreeNode *rChild; int lTag,rTag; }BiTreeNode; //全局变量 BiTreeNode *pre =NULL; BiTreeNode *point[MAX+1]; //构建二叉树时辅助,用于定位子节点 //构建二叉树 BiTreeNode *CreateBiTree() { BiTreeNode *root=(BiTreeNode *)malloc(sizeof(BiTreeNode)); int i,j;char data; cout<<"输入结点索引值i,和结点值data,以0 #结束\n"; cin>>i>>data; while(i!=0&&data!='#') { BiTreeNode *newNode=(BiTreeNode *)malloc(sizeof(BiTreeNode)); newNode->data=data; newNode->lTag=0;newNode->rTag=0; newNode->lChild=NULL;newNode->rChild=NULL; point[i]=newNode; if(i==1) //为二叉树根节点 { root=point[1]; } else { j=i/2; if(i%2==0) //为左孩子结点 { point[j]->lChild=newNode; } else { point[j]->rChild=newNode; } } cin>>i>>data; } return root; } //中序线索化二叉树,pre初始化为NULL void Inthread(BiTreeNode *root) { if(root!=NULL) { Inthread(root->lChild); if(root->lChild==NULL) { root->lTag=1;root->lChild=pre; } if(pre!=NULL&&pre->rChild==NULL) { pre->rTag=1;pre->rChild=root; } pre=root; Inthread(root->rChild); } } //查找结点p的前驱结点 BiTreeNode *InPre(BiTreeNode *p) { if(p->lTag==1)return p->lChild; BiTreeNode *q=p->lChild; if(q==NULL){ cout<<"无前驱结点\n"; return NULL; } while(q->rTag!=1) { q=q->rChild; } return q; } //查找结点p的后继结点 BiTreeNode *InSub(BiTreeNode *p) { if(p->rTag==1)return p->rChild; BiTreeNode *q=p->rChild; if(q==NULL){ cout<<"无后继结点\n"; return NULL; } while(q->lTag==0) { q=q->lChild; } return q; } //插入结点到线索二叉树 bool InsertNode(BiTreeNode *p,int index,char method) { if(method!='l'&&method!='L'&&method!='r'&&method!='R') { cout<<"命令有误,插入方式为l,L,r,R.\n"; return false; } if(point[index]==NULL) //不存在该结点 { cout<<"插入的位置无效\n"; return false; } if(method=='l'||method=='L') //插入为poinit[index]所指向结点的左孩子结点O(∩_∩)O~有点拗口 { if(point[index]->lTag==1) //插入位置的结点无左孩子结点 { p->lChild=point[index]->lChild; point[index]->lChild=p; p->lTag=1;p->rTag=1; point[index]->lTag=0; } else //有左孩子结点,需找到point[index]左子树最右下角的结点 { BiTreeNode *s=point[index]->lChild; while(s->rTag==0)s=s->rChild; p->lChild=point[index]->lChild; point[index]->lChild=p; s->rChild=p; p->lTag=0;p->rTag=1; } point[index*2]=p; } if(method=='r'||method=='R') { if(point[index]->rTag==1) //无右孩子结点 { p->rChild=point[index]->rChild; point[index]->rChild=p; p->lChild=point[index]; point[index]->rTag=0; p->rTag=1;p->lTag=1; } else //存在有孩子结点,需找到右子树最左下角的结点 { BiTreeNode *s=point[index]->rChild; while(s->lChild==0)s=s->lChild; p->rChild=point[index]->rChild; point[index]->rChild=p; p->lChild=point[index]; p->rTag=0;p->lTag=1; s->lChild=p; } point[index*2+1]=p; } return true; } int main() { char cmd,data;int index; do{ BiTreeNode *root=CreateBiTree(); Inthread(root); cout<<"输入您要查找的结点,序号index\n"; cin>>index; BiTreeNode *nodePre=InPre(point[index]); BiTreeNode *nodeSub=InSub(point[index]); if(nodePre!=NULL) cout<<"结点"<<index<<"的前驱结点的值为"<<nodePre->data<<"\n"; if(nodeSub!=NULL) cout<<"结点"<<index<<"的后继结点的值为"<<nodeSub->data<<"\n"; cout<<"\n"<<"输入插入结点的值,及插入的位置,插入的方式(l,r or L,R)\n"; cin>>data>>index>>cmd; BiTreeNode *p=(BiTreeNode *)malloc(sizeof(BiTreeNode)); p->data=data; InsertNode(p,index,cmd); cout<<"继续吗Y/y?\n"; cin>>cmd; }while(cmd=='Y'||cmd=='y'); return 0; }
发表评论
-
【排序算法系列】希尔排序
2015-12-05 16:14 846希尔排序的概述: a[0]...a[n-1 ... -
归并排序
2015-06-20 15:28 900public class MergeSort { pub ... -
插入排序
2015-06-20 15:27 487/** * 插入排序1 容易理解 * * ... -
有序线性链表归并
2013-10-05 11:30 1566#include<stdio.h> #incl ... -
Trie树 应用 Phone List
2012-06-15 11:21 1181Phone List 时间限 ... -
Trie树 单词查找树 键树(JAVA版附分析说明)
2012-06-13 10:27 5184来源于英文“retrieval”. ... -
Trie树 单词查找树 键树
2012-06-12 08:59 1159转自:http://zh.wik ... -
数字金额转中文大写金额
2010-11-26 15:09 1430/** * 用来将数字金额转化成中文大写的金额 ... -
汉诺塔递归算法
2010-11-25 08:17 1356import java.util.Scanner; /* ... -
约瑟夫出圈
2010-11-24 20:45 1101#include<iostream> #incl ... -
SmartHashSet只是为了解释HashSet的原理
2010-07-26 11:11 1365写该类的目的只是为了 ... -
二叉树中序遍历非递归算法
2010-06-29 23:17 1726#include<iostream> usi ... -
二叉树的创建
2010-06-29 23:15 1137#include<iostream> usi ... -
哈弗曼树建立与哈弗曼编码
2010-06-29 23:12 1251#include<iostream> #de ... -
二叉排序树转双向链表(要求无任何新增节点)
2010-06-29 23:07 2495题目:输入一棵二元查找树,将该二元查找树转换成一个排序的双 ... -
二叉排序树的递归与非递归查找
2010-06-29 22:58 2313#include<iostream> usi ... -
二叉树中序线索化及查找某一结点的前驱,后继结点
2010-06-29 22:54 2687#include<iostream> usi ... -
十字链表定义创建查找
2010-06-29 22:44 1324#include<iostream> #defi ... -
稀疏矩阵转置
2010-06-29 22:39 1670#include<iostream> #defi ... -
单链表实现集合并交差操作
2010-06-29 22:34 2006#include<iostream> usi ...
相关推荐
通过前序序列创建线索二叉树 1:中序遍历 2:查找节点前驱后继 3:插入节点 4:删除节点 0:退出
在线索二叉树中插入节点时,需要考虑以下几点: 1. 如果新插入的节点是叶子节点,那么它将连接到已存在的节点上,同时更新相关线索。如果它是左孩子,那么它的前驱线索应指向其父节点;如果它是右孩子,那么它的后继...
线索二叉树的插入可以通过找到要插入的位置并将新结点插入到该位置来实现。该过程可以分为以下步骤: 1. 找到要插入的位置。 2. 创建一个新结点,并将其插入到要插入的位置。 3. 将新结点的前驱结点和后继结点的...
在二叉链表的每个节点中增加两个附加指针,称为线索,分为`ltag`和`rtag`,分别表示左孩子指针是否为前驱线索,右孩子指针是否为后继线索。同时,还需要额外的标志位来区分普通指针和线索。 在C++中,我们可以通过...
线索二叉树通过在每个节点中添加额外的线索(指针)来解决这个问题,这些线索指向该节点在某种遍历时的前驱或后继节点。这样,我们就可以使用迭代而非递归的方式进行遍历,提高了算法效率。 线索二叉树中的每个节点...
在中序线索二叉树中,新结点的插入可能会影响其前驱和后继结点的线索。插入新结点时,需要检查新结点的父结点和兄弟结点,以确保线索的正确更新。如果新结点是父结点的左孩子,那么父结点的左线索应指向新结点;如果...
在中序线索二叉树中,我们可以快速地从前一个节点找到后一个节点,而无需通过父节点进行跳转。这一过程涉及到对二叉树节点的修改,添加两个额外的指针,称为“前向线索”(in-order predecessor pointer)和“后向...
在普通的二叉查找树中,我们通常只能通过指针找到左右子节点,但在线索二叉树中,我们可以从前向后(前驱线索)和从后向前(后继线索)遍历节点,使得在非递归情况下也能进行中序、前序和后序遍历。 线索二叉树的...
- **插入**:在已有线索二叉树中插入新的节点,同时更新线索信息,保持线索的正确性。 - **删除**:从线索二叉树中删除指定节点,同样需要更新线索信息。 - **线索化**:将普通二叉树转换为线索二叉树,即在遍历...
例如,在插入结点时,我们需要找到插入结点的前驱和后继结点,然后将其连接起来。在删除结点时,我们需要找到删除结点的前驱和后继结点,然后将其连接起来。 线索二叉树是一种特殊的二叉树,它的结构和性质使得我们...
线索二叉树通过在二叉树的每个节点中添加额外的线索(thread)指向其前驱或后继节点,使得非递归的遍历方式成为可能,从而提高了查找效率。 在构建线索二叉树时,我们需要在二叉树的叶子节点和非叶子节点上分别处理...
线索二叉树是一种特殊的二叉树,它是在普通的二叉链表基础上进行改造,以便在二叉树中方便地进行前序、中序和后序遍历。在标准的二叉链表中,每个节点仅包含指向左孩子和右孩子的指针,但没有直接指向其前驱和后继...
在C++或Java等面向对象的语言中,我们可以定义一个`Node`类表示线索二叉树的节点,包含数据、左右孩子指针和前驱后继线索。接着实现`BinaryThreadedTree`类,提供插入、删除、遍历等相关操作。对于每个操作,都需要...
定义了结构体 `BiThrNode` 表示线索二叉树的节点,包括数据元素 `data`,以及指向左子节点 `lchild`、右子节点 `rchild` 的指针,还有两个枚举类型 `PointerTag` 表示指针类型,`Link` 表示普通指针,`Thread` 表示...
线索二叉树是二叉树的一种优化形式,通过在节点中添加线索来改善遍历效率。在C语言中,我们可以利用结构体和指针来构建和操作线索二叉树。虽然实现过程比普通二叉树更复杂,但线索二叉树在处理大规模数据时能带来...
在`ThreadTree`这个文件中,可能包含了实现线索二叉树的类定义、节点结构以及相关的插入、删除、遍历等方法。具体实现细节需要查看源代码才能得知。 总结来说,线索二叉树通过引入线索,优化了二叉搜索树的遍历性能...
总之,线索二叉树是一种增强二叉树遍历能力的数据结构,通过在节点中添加线索指针,使得非递归遍历成为可能,尤其在处理反向遍历时更为高效。C语言作为一种底层语言,非常适合实现这样的数据结构,通过结构体和指针...
在二叉链表的每个节点中,除了原有的左子节点(left)和右子节点(right)指针外,我们还会添加两个新的字段:前驱线索(left_thread)和后继线索(right_thread)。当某个节点没有左子节点时,它的left_thread将...