- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
建立一个排序二叉树
建立一个排序二叉树,并给出中序遍历该排序二叉树的结果
#include stdafx.h#includeiostreamusing namespace std;//-----------排序二叉树节点--------------//struct tree //定义二叉树节点结构{int data;?? //节点数据域tree *right,*left; //右,左子树指针};
//-----------排序二叉树类----------------//class Btree {tree *root;//根节点public:Btree(){?? root=NULL;//根节点在构造函数里初始化}void create_btree(int);//创建排序二叉树void display() //显示进行中序遍历排序后的数据{?? inorder(root);//调用中序遍历排序函数?? coutendl;}void inorder(tree *);//进行中序遍历排序};
void Btree::create_btree(int t){tree *newnode=new tree;//创建新的节点存入数据并插入二叉树中newnode-data =t;??????? //存入数据tnewnode-left =NULL;???? newnode-right =NULL;if(root==NULL) //当是根节点为空时即二叉树中没有任何数据时{?? root=newnode; //根节点为新节点}else???????? //当有二叉树中拥有数据后{?? tree *back; ?? tree *current;?? current=root; ??? while(current!=NULL) ?? {??? back=current; //记住current的父节点??????????? if(current-datat)???? current=current-left;??? else current=current-right ;?? }?? if(back-datat)??? back-left =newnode;?? else back-right =newnode;}}void Btree::inorder (tree* tmp)//采用递归进行中序遍历{if(tmp!=NULL){?? inorder(tmp-left);?? couttmp-data ;?? inorder(tmp-right );}}
int main(int argc, char* argv[]){??? Btree A;int arr[]={7,4,1,5,12,8,13,11};cout建立排序二叉树顺序:endl;for(int i=0;i8;i++){?? coutarr[i] ;?? A.create_btree(arr[i]);}coutendl中序遍历序列:endl;A.display ();printf(Hello World!\n);return 0;}
将单链表拆分成一个偶数链表和奇数链表
程序如??:
#include stdio.h
#include stdlib.h
typedef struct node
{
char data;
struct node *nextPtr;
}*LinkList, Lnode;
static void CreateList(LinkList *headPtr, LinkList *tailPtr, char ch);
static void Decompose(LinkList *headPtrA, LinkList *headPtrB, LinkList *tailPtrB);
static void VisitList(LinkList headPtr);
static void DestroyList(LinkList *headPtr, LinkList *tailPtr);
int main(void)
{
LinkList headPtrA = NULL, tailPtrA = NULL, headPtrB = NULL, tailPtrB = NULL;
char ch;
while (1)
{
printf(Enter ch(@-quit): );
scanf( %c, ch);
if (ch == @)
{
break;
}
else
{
CreateList(headPtrA, tailPtrA, ch);
}
}
Visit
文档评论(0)