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

医联媒体网站建设网站建设网站制作公司

医联媒体网站建设,网站建设网站制作公司,wordpress多站点怎么安装主题,产品建站工具🔥个人主页:草莓熊Lotso 🎬作者简介:C研发方向学习者 📖个人专栏: 《C语言》 《数据结构与算法》《C语言刷题集》《Leetcode刷题指南》 ⭐️人生格言:生活是默默的坚持,毅力是永久的…

 🔥个人主页:@草莓熊Lotso

🎬作者简介:C++研发方向学习者

📖个人专栏: 《C语言》 《数据结构与算法》《C语言刷题集》《Leetcode刷题指南》

⭐️人生格言:生活是默默的坚持,毅力是永久的享受。 

前言:在之前的C语言刷题集中我们刷了很多IO类型的基础编程题,但是随着数据结构往后的学习以及企业面试的要求,我们还需要对接口型的题目进行练习,博主在这里准备了新的《LeetCode刷题指南》专栏给大家分享一些我自己在力扣上面写过的题目,提供一些我的解题思路。个人实力有限,欢迎大家补充和指正。


目录

一.对称二叉树

解题过程:

代码实现: 

二.另一颗树的子树

解题过程:

代码实现: 


一.对称二叉树

题目链接:101. 对称二叉树 - 力扣(LeetCode)

 题目描述:

题目示例: 

思路: 递归

解题过程:

1.判断当前树的左右子树是不是相同的树

2.调用相同的树的代码,具体操作在之前的题目中讲过

3.但是要注意相同的树判断代码里这里和之前的不太一样

具体过程如图所示: 

复杂度: 

  • 时间复杂度: O(n)
  • 空间复杂度: O(n)

代码实现: 

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     struct TreeNode *left;*     struct TreeNode *right;* };*/
typedef struct TreeNode TreeNode;
bool isSameTree(TreeNode*p,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->right)&&isSameTree(p->right,q->left);
}bool isSymmetric(struct TreeNode* root) {return isSameTree(root->left,root->right);
}

二.另一颗树的子树

题目链接:572. 另一棵树的子树 - 力扣(LeetCode)

题目描述: 

题目示例: 

思路: 递归

解题过程:

1.在isSubtree函数里,如果root为空直接返回false
2.如果root不为空,先拿当前root和Subtree比较,看是否是相同的树(这里调用之前写过的相同的树的函数,没有需要修改的地方)
3.如果不为空也不是相同的树,则继续传左孩子或者右孩子递归,有任意一个符合isSubtree就可以
具有操作如图所示:

复杂度: 

  • 时间复杂度: O(n)
  • 空间复杂度: O(n)

代码实现: 

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     struct TreeNode *left;*     struct TreeNode *right;* };*/bool isSameTree(struct TreeNode* p, struct TreeNode* q) {//p和q都为空if(p==NULL && q==NULL){return true;}//p和q只有一个为空,前面提前判断过全为空处理了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) {//如果root为空则返回falseif(root==NULL){return false;}//如果是相等的树就返回trueif(isSameTree(root,subRoot)){return true;}//如果这次不相等,就传左右孩子节点。左右子树任一有一个和subRoot相同就可以return isSubtree(root->left,subRoot)||isSubtree(root->right,subRoot);
}

往期回顾:

【LeetCode刷题指南】--有效的括号

【LeetCode刷题指南】--队列实现栈,栈实现队列

【LeetCode刷题指南】--单值二叉树,相同的树

【LeetCode刷题指南】--二叉树的前序遍历,二叉树的中序遍历

结语:本篇文章就到此结束了,《LetetCode刷题指南》中的题目比起之间的C语言刷题集中的题目,肯定会更加复杂一些。而且题目形式也不一样,大家需要注意一下。如果文章对你有帮助的话,欢迎评论,点赞,收藏加关注,感谢大家的支持。

http://www.dtcms.com/a/415473.html

相关文章:

  • Detectron2 - 下一代目标检测与分割算法库
  • CSS过渡效果完全指南
  • 木门行业网站该怎么做封面制作网站
  • AIPyApp - Python 智能执行环境
  • 深度学习中Bootstrap详解
  • 网站关键字优化合同深圳网站制作公司资讯
  • 网络销售型网站有哪些内容百度推广培训机构
  • html制作一个个人主页网站wordpress首页调用指定文章
  • 安宝特科技丨【行业首发】Vuzix LX1智能眼镜:仓储物流的下一代智能助手
  • 无锡建行网站重庆网站备案最快几天
  • 河津网站建设湖南建设工程信息网官网
  • Ubuntu服务器版增加中文支持
  • 宁波网站推广营销江苏中南建设集团网站是多少
  • 那些网站企业可以免费展示动画制作软件flash官方下载
  • C++笔记(面向对象)类的定义
  • 电子信息工程专业课《数字信号处理》课程简介
  • 【攻防实战】对抗中的特殊场景上线cs和msf
  • 如何利用网站做demo北京公司网站建设报价
  • 显存带宽瓶颈突破:基于TensorRT的实时4K视频渲染优化
  • 陕西网站制作公司宁波网站建设排名
  • 网站开发设计会议网站怎么做
  • OpenHarmony中的系统服务管理配置讲解
  • 如何接做网站编程的生意做a免费网站有哪些
  • 王玉真:可信资产与数链金融的核心根基——构建全链路可信信用体系
  • 网页制作与网站建设文档石家庄seo排名公司
  • C#语言——类型、变量与对象
  • 网络科技公司 网站建设网站 公司形象
  • 黑龙江省网站建设百度里面企业网站怎么建设
  • 【Qt】输入类控件1——QLineEdit,QTextEdit,ComboBox
  • 一家专门做内部优惠的网站石柱县建设局网站