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

营销型网站建设公司排名免费php网站模板下载

营销型网站建设公司排名,免费php网站模板下载,公司网页申请,吉林网站建站系统哪家好1.二叉树的前序遍历 144. 二叉树的前序遍历https://leetcode.cn/problems/binary-tree-preorder-traversal/这个题目在遍历的基础上还要求返回数组,数组里面按前序存放二叉树节点的值。 既然要返回数组,就必然要malloc一块空间,那么我们需…

1.二叉树的前序遍历 

144. 二叉树的前序遍历icon-default.png?t=N7T8https://leetcode.cn/problems/binary-tree-preorder-traversal/这个题目在遍历的基础上还要求返回数组,数组里面按前序存放二叉树节点的值。

既然要返回数组,就必然要malloc一块空间,那么我们需要算出这个二叉树的节点个数,所以就创建一个函数TreeSize求出节点个数。TreeSize的实现在上篇文章有提到http://t.csdnimg.cn/izhvv

 所以在preorderTraversal里面创建一个变量n来接收TreeSize的返回值,再为变量amalloc一块空间,空间大小是n个int。这个时候就要考虑如何存放前序的值,写一个函数PrevOrder,参数是头指针root,数组a,指针变量pi,进入函数首先判断当前节点是否为空,如果是空则返回,不是空则开始存值,将root->val存在a[*pi]这个位置,然后(*pi)++,然后就是递归左右子树。在preorderTraversal内部创建变量i,&i作为PrevOrder参数,再将*returnsize=n,最后返回数组a即可。

int TreeSize(struct TreeNode* root)
{return root==NULL?0:TreeSize(root->left)+TreeSize(root->right)+1;
}
void PrevOrder(struct TreeNode* root,int* a,int* pi)
{if(root==NULL)return ;a[(*pi)++]=root->val;PrevOrder(root->left,a,pi);PrevOrder(root->right,a,pi);
}
int* preorderTraversal(struct TreeNode* root, int* returnSize) 
{int n=TreeSize(root);int* a=(int*)malloc(sizeof(int)*n);int i=0;PrevOrder(root,a,&i);*returnSize=n;return a;
}

 2.判断两棵树是否相同

100. 相同的树icon-default.png?t=N7T8https://leetcode.cn/problems/same-tree/

 首先判断这两棵树是否都是空树,如果都是空树则return true,如果没有返回true则说明有以下情况:1.p==NULL,q!=NULL. 2.p!=NULL,q==NULL. 3.q!=NULL,p!=NULL.下一步就是判断,既然有一棵树为NULL,那么如果另一棵树不为NULL,则返回false,巧妙地利用||逻辑运算符,因为已知走到这一步至少有一棵树不为NULL,所以两个条件至少有一个不成立,||运算符是有一个成立则成立,所以如果另一棵树为NULL则返回false,那么现在只剩下一种情况,两棵树都不为空。这个时候判断当前两棵树的节点的值是否相同即可,如果不相等则返回false。最后递归左右子树,这里需要注意的是,如果左树已经不相同而返回false的话就没必要走右树了,所以使用&&逻辑运算符。

bool isSameTree(struct TreeNode* p, struct TreeNode* q) 
{//都为空if(p==NULL&&q==NULL)return true;//其中一个为空if(p==NULL||q==NULL)return false;if(q->val!=p->val)return false;return isSameTree(p->left,q->left)&&isSameTree(p->right,q->right);}

3.判断一棵树是否为另一棵树的子树

572. 另一棵树的子树icon-default.png?t=N7T8https://leetcode.cn/problems/subtree-of-another-tree/

 这里我们可以拷贝上一题的代码,判断是否树相同。首先判断root这棵树是否为空树,如果是空树则返回false。再判断root的值val是否与subRoot的值val相同,如果相同则使用isSameTree判断从当前节点开始两棵树是否相同,如果相同则返回true。最后递归判断一下root的左子树和右子树,这里可以使用||逻辑运算符,因为无论是左边还是右边,有一边中的子树和subRoot相同即可。

bool isSameTree(struct TreeNode* p, struct TreeNode* q)
{//都为空if (p == NULL & q == NULL)return true;//其中一个为空if (p == NULL || q == NULL)return false;if (q->val != p->val)return false;return isSameTree(p->left, q->left) && isSameTree(p->right, q->right);}
bool isSubtree(struct TreeNode* root, struct TreeNode* subRoot)
{if(root==NULL)return false;if(root->val==subRoot->val){if(isSameTree(root,subRoot))return true;}return isSubtree(root->left,subRoot)||isSubtree(root->right,subRoot);
}

 今天的分享到这里就结束了,感谢大家的阅读!

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

相关文章:

  • app网站建设可行性分析深圳小程序服务商
  • 网站域名过期怎么做电子商务网站建设课程性质
  • 学校网站建设流程图建个静态网站
  • 网站的优化策略方案拉新平台
  • 建设部规范网站获奖类网站建设推广策划案
  • 青岛做网站的管家婆客户管理系统
  • 工业品公司做商城网站好吗惠州学院网站建设
  • xp花生壳做自己的网站如何充实网站内容
  • 虚拟电子商务网站建设前期规划方案龙华区民治街道
  • 做网站上饶c 能用来做网站
  • 网站建设通用代码学校做网站一般多少钱
  • 嘉禾手机网站建设网页制作公司介绍
  • 网站开发总结与收获韩国网站 后缀
  • 用php做的网站怎么上传玖玖建筑网官方网
  • 网站运营维护郴州网红景点
  • 获取网站浏览者手机号海口网站建设做网站
  • 网站开发的项目流程图网站规划与建设 第2版ppt
  • 手机网站被禁止访问怎么设置打开镇江网站seo公司
  • 苏州高端网站制作官网网站排名推广的优点是什么
  • 北京做环评备案的网站wordpress实现注册功能
  • 做网站改版的公司网站制作费用申请
  • 电商网站会员体制怎么做大连宏帝建设网站
  • 基于开源框架的网站开发拓者设计吧手机版
  • 购买游戏软件做网站wordpress文章底部添加自定义内容
  • 个人网站建设的流程免费的招标网站有哪些
  • 做网站可以自由职业吗贵阳网站开发哪家便宜
  • 河南电力建设工程公司网站桂林人论坛桂林板路
  • 西安seo网站管理接私活app有哪些平台
  • 韩国平面设计网站西安企业排名
  • 优质服务的小企业网站建设网站申请服务器空间