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

北京公司网站制作改进网站建设英文作文

北京公司网站制作,改进网站建设英文作文,做网站 宁波,怎么查网站的外链144. 二叉树的前序遍历难度简单给你二叉树的根节点 root #xff0c;返回它节点值的 前序 遍历。示例 1#xff1a;输入#xff1a;root [1,null,2,3]输出#xff1a;[1,2,3]示例 2#xff1a;输入#xff1a;root [ ]输出#xff1a;[ ]示例 3#xff1a;输入#…144. 二叉树的前序遍历难度简单给你二叉树的根节点 root 返回它节点值的 前序 遍历。示例 1输入root [1,null,2,3]输出[1,2,3]示例 2输入root [ ]输出[ ]示例 3输入root [1]输出[1]示例 4输入root [1,2]输出[1,2]示例 5输入root [1,null,2]输出[1,2] 提示树中节点数目在范围 [0, 100] 内-100 Node.val 100 进阶递归算法很简单你可以通过迭代算法完成吗/*** Definition for a binary tree node.* struct TreeNode {* int val;* struct TreeNode *left;* struct TreeNode *right;* };*/ /*** Note: The returned array must be malloced, assume caller calls free().*/ int* preorderTraversal(struct TreeNode* root, int* returnSize){}解析代码ps迭代算法我们要学了C之后的高阶数据结构再实现int TreeSize(struct TreeNode* root) {if(rootNULL){return 0;}return 1 TreeSize(root-left) TreeSize(root-right); }void _preorderTraversal(struct TreeNode* root,int* array,int* pi) // (函数前面的_代表这个函数的子函数) {if(rootNULL){return;}array[(*pi)] root-val;_preorderTraversal(root-left,array,pi);_preorderTraversal(root-right,array,pi); }int* preorderTraversal(struct TreeNode* root, int* returnSize){int size TreeSize(root);int* array(int*)malloc(sizeof(int)*size);int i 0;_preorderTraversal(root,array,i);*returnSizesize;return array; }写完这题可以去写写二叉树的中序遍历和后序遍历都是一样的链接94. 二叉树的中序遍历965. 单值二叉树难度简单如果二叉树每个节点都具有相同的值那么该二叉树就是单值二叉树。只有给定的树是单值二叉树时才返回 true否则返回 false。 示例 1输入[1,1,1,1,1,null,1]输出true示例 2输入[2,2,2,5,2]输出false 提示给定树的节点数范围是 [1, 100]。每个节点的值都是整数范围为 [0, 99] 。/*** Definition for a binary tree node.* struct TreeNode {* int val;* struct TreeNode *left;* struct TreeNode *right;* };*/bool isUnivalTree(struct TreeNode* root){}解析代码bool isUnivalTree(struct TreeNode* root) {if (root NULL){return true;}if (root-left root-val ! root-left-val){return false;}if (root-right root-val ! root-right-val){return false;}return isUnivalTree(root-left) isUnivalTree(root-right); }104. 二叉树的最大深度难度简单给定一个二叉树找出其最大深度。二叉树的深度为根节点到最远叶子节点的最长路径上的节点数。说明: 叶子节点是指没有子节点的节点。示例给定二叉树 [3,9,20,null,null,15,7] 3 / \ 9 20 / \ 15 7返回它的最大深度 3 。/*** Definition for a binary tree node.* struct TreeNode {* int val;* struct TreeNode *left;* struct TreeNode *right;* };*/int maxDepth(struct TreeNode* root){}解析代码/*int maxDepth(struct TreeNode* root) {if (root NULL){return 0;}return maxDepth(root-left) maxDepth(root-right) ? maxDepth(root-left) 1 : maxDepth(root-right) 1; }*/ //这样写会有重复的递归计算 优化 int maxDepth(struct TreeNode* root) {if (root NULL){return 0;}int leftDepth maxDepth(root-left);int rightDepth maxDepth(root-right);return leftDepth rightDepth ? leftDepth 1 : rightDepth 1; }226. 翻转二叉树难度简单给你一棵二叉树的根节点 root 翻转这棵二叉树并返回其根节点。 示例 1输入root [4,2,7,1,3,6,9]输出[4,7,2,9,6,3,1]示例 2输入root [2,1,3]输出[2,3,1]示例 3输入root []输出[] 提示树中节点数目范围在 [0, 100] 内-100 Node.val 100/*** Definition for a binary tree node.* struct TreeNode {* int val;* struct TreeNode *left;* struct TreeNode *right;* };*/struct TreeNode* invertTree(struct TreeNode* root){}解析代码法一struct TreeNode* invertTree(struct TreeNode* root) {if (root NULL){return NULL;}struct TreeNode* tmp root-left;root-left root-right;root-right tmp;invertTree(root-left);invertTree(root-right);return root; }解析代码法二struct TreeNode* invertTree(struct TreeNode* root) {if (root NULL){return NULL;}struct TreeNode* rightTmp root-right;root-right invertTree(root-left);root-left invertTree(rightTmp);return root; }100. 相同的树难度简单给你两棵二叉树的根节点 p 和 q 编写一个函数来检验这两棵树是否相同。如果两个树在结构上相同并且节点具有相同的值则认为它们是相同的。 示例 1输入p [1,2,3], q [1,2,3]输出true示例 2输入p [1,2], q [1,null,2]输出false示例 3输入p [1,2,1], q [1,1,2]输出false 提示两棵树上的节点数目都在范围 [0, 100] 内-10^4 Node.val 10*4/*** Definition for a binary tree node.* struct TreeNode {* int val;* struct TreeNode *left;* struct TreeNode *right;* };*/bool isSameTree(struct TreeNode* p, struct TreeNode* q){}解析代码bool isSameTree(struct TreeNode* p, struct TreeNode* q) {if (p NULL q NULL){return true;}if (p NULL || q NULL)//其中一个为空另一个不为空{return false;}if (p-val ! q-val){return false;}return isSameTree(p-left, q-left) isSameTree(p-right, q-right); }572. 另一棵树的子树难度简单给你两棵二叉树 root 和 subRoot 。检验 root 中是否包含和 subRoot 具有相同结构和节点值的子树。如果存在返回 true 否则返回 false 。二叉树 tree 的一棵子树包括 tree 的某个节点和这个节点的所有后代节点。tree 也可以看做它自身的一棵子树。 示例 1输入root [3,4,5,1,2], subRoot [4,1,2]输出true示例 2输入root [3,4,5,1,2,null,null,null,null,0], subRoot [4,1,2]输出false 提示root 树上的节点数量范围是 [1, 2000]subRoot 树上的节点数量范围是 [1, 1000]-10^4 root.val 10^4-10^4 subRoot.val 10^4/*** Definition for a binary tree node.* struct TreeNode {* int val;* struct TreeNode *left;* struct TreeNode *right;* };*/bool isSubtree(struct TreeNode* root, struct TreeNode* subRoot) {}解析代码bool isSameTree(struct TreeNode* p, struct TreeNode* q) {if (p NULL q NULL){return true;}if (p NULL || q NULL)//其中一个为空另一个不为空{return false;}if (p-val ! q-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 (isSameTree(root, subRoot)){return true;}//不一样就递归遍历这棵树return isSubtree(root-left, subRoot)|| isSubtree(root-right, subRoot);//只要有一个root返回true就行 }
http://www.yingshimen.cn/news/66449/

相关文章:

  • 做简单网站需要学什么网络运营策划
  • 动漫做3d游戏下载网站wordpress log in
  • 怎么降低网站的跳出率九江市seo
  • 郑州公司做网站汉狮东莞保安公司排名
  • 河北省建设局网站2017网站建设趋势
  • 织梦如何做汽车贸易网站域名怎么注册
  • 吉林省长春网站建设wordpress 默认页面
  • flash网站读条怎么做自己做电影资源网站
  • 音乐主题的网站设计wordpress 浏览计数
  • 怎么进入网站开发模式云主机 免费
  • 保定网站设计制作需要多少钱江苏中高风险地区名单
  • php网站的部署网站要背代码?
  • 网站开发难点网站建设丨找王科杰效果好
  • 前程无忧网宁波网站建设类岗位西安推广网络排行
  • 个人网站建设方案书使用几号纸做网站去什么公司
  • 如何做电商网站中关村手机在线频道
  • 闵行集团网站建设简述网站建设的五类成员
  • 网站首页设计过程服务外包公司是干什么的
  • 中国空间站什么时候建成在郑州做网站
  • 还有哪些数据库网站攸县做网站的
  • ppp项目建设交易网站建站用Wordpress还是
  • 住房与城乡建设部网站注册中心不同网站建设特点
  • 网站建设技术要求极致cms模板
  • 千锋教育前端培训网站seo公司哪家好
  • 网站做电商资质吉林省软环境建设办公室网站
  • 网站建设 软件开发酒店网站 asp.net
  • 桥头网站建设公司上海做网站去哪里
  • 浙江交工宏途交通建设有限公司网站6开发软件需要多少成本
  • 中国空间站结构示意图网站做商标在那类
  • 商务网站建设sz886做外贸是用什么网站做