小奥的学习笔记

  • Home
  • Learning & Working
    • Speech Enhancement Notes
    • Programming language
    • Computer & DL
    • MOOC
  • Life
    • Life Time
    • Thinking & Comprehension
    • Volunteer
    • Plan
    • Travel
  • Footprints
  • GuestBook
  • About
    • About Me
    • 个人履历
    • 隐私策略
  1. 首页
  2. Study-notes
  3. Programming language
  4. Algorithm
  5. Leetcode
  6. 正文

Leetcode题目解析(191016)

2019年10月16日 1066点热度 0人点赞 0条评论

Leetcode 572:另一个树的子树

题目描述

给定两个非空二叉树 s 和 t,检验 s 中是否包含和 t 具有相同结构和节点值的子树。s 的一个子树包括 s 的一个节点和这个节点的所有子孙。s 也可以看做它自身的一棵子树。

示例

7ca37b3c6aa82f235c77db4e0ebd8239.png

7ca37b3c6aa82f235c77db4e0ebd8239.png

解题思路

这个题我用两个函数来实现的,首先是官方给的isSubtree()函数,它主要是来做寻找到S和T第一个相同的结点。第二个函数就是isSub()函数,它主要是用来在找到这个结点之后,子树的判断。
它们的思路如下:

isSubtree()函数

s为空,则一定false;

然后判断当前S和T的结点值是否相等(isSub子函数),若相等,返回true(if语句括号里面收到true的时候,一定是在isSub所有点都比较完成了);

若当前值不相等,那么分别看s的左子树和s的右子树里面有没有相等的。

isSub()函数

如果当前点都为null,那么这一步是相等的,return true;

如果当前点一个有值,一个为空,那么一定是false(两个点都为空的情况在上面已经返回了,所以这里肯定没有);

如果当前点两个值不相等,那么没必要比较下去了,直接return false;

如果当前点的两个值相等,那么分别比较左子树和右子树。

代码实现

bool isSub(TreeNode* s, TreeNode* t)
{
    if (!s && !t)
        return true;
    if (!s || !t)
        return false;
    if (s->val != t->val)
        return false;
    return isSub(s->left, t->left) && isSub(s->right, t->right);
}
bool isSubtree(TreeNode* s, TreeNode* t) {
    if (!s)
        return false;
    if (isSub(s, t))
        return true;
    return isSubtree(s->left, t) || isSubtree(s->right, t);
}

Leetcode 581:最短无序连续子数组

题目描述

给定一个整数数组,你需要寻找一个连续的子数组,如果对这个子数组进行升序排序,那么整个数组都会变为升序排序。你找到的子数组应是最短的,请输出它的长度。

示例

示例1
输入: [2, 6, 4, 8, 10, 9, 15]
输出: 5
解释: 你只需要对 [6, 4, 8, 10, 9] 进行升序排序,那么整个表都会变为升序排序。

解题思路

我的思路很简单,对整个数组进行排序,然后图方便,将所有与原来相同位置上数字不同的位置记录下来,然后记录start为第一个位置,end为最后一个位置,结果就是end-start-1。当然也可以用其它方法只记录end和start,节省空间。

之所以这样做是因为,找到的子数组是最短的,说明应该找的是第一个动的位置和最后一个动的位置及包含它们在内的子数组,所以才这样做。

代码实现

int findUnsortedSubarray(vector<int>& nums) {
    vector<int>tmp(nums);
    sort(nums.begin(), nums.end());
    vector<int>pos;
    for (int i = 0; i < nums.size(); i++)
    {
        if (nums[i] != tmp[i])
        {
            pos.push_back(i);
        }
    }
    int posize = pos.size();
    if(posize==0)
        return 0;
    int start = pos[0];
    int end = pos[pos.size() - 1];
    //cout << "start=" << start << "end=" << end << endl;
    return (end - start + 1);
}
本作品采用 知识共享署名 4.0 国际许可协议 进行许可
标签: leetcode 算法
最后更新:2019年10月16日

yszhang

这个人很懒,什么都没留下

打赏 点赞
< 上一篇
下一篇 >

文章评论

razz evil exclaim smile redface biggrin eek confused idea lol mad twisted rolleyes wink cool arrow neutral cry mrgreen drooling persevering
取消回复

搜索
欢迎关注我的个人公众号
最新 热点 随机
最新 热点 随机
DEEPFILTERNET:一种基于深度滤波的全频带音频低复杂度语音增强框架 奥地利匈牙利九日游旅程 论文阅读之Study of the General Kalman Filter for Echo Cancellation 小奥看房之鸿荣源珈誉府 杭州往返旅途及西溪喜来登和万怡的体验报告 2022年的第一篇碎碎念
奥地利匈牙利九日游旅程论文阅读之Study of the General Kalman Filter for Echo CancellationDEEPFILTERNET:一种基于深度滤波的全频带音频低复杂度语音增强框架
我的大学应当怎样度过 Java语言程序设计(进阶)(第六章)整理 第一次使用git更新github过程和遇到的问题 C++面向对象程序设计课程笔记(第三周) 这是一种成长吗? 全运会本人观赛日程(更新完毕)
标签聚合
鸟哥的linux私房菜 linux leetcode 算法 Java python学习 生活 Python 学习 高中
最近评论
davidcheung 发布于 6 个月前(02月09日) The problem has been fixed. May I ask if you can s...
tk88 发布于 6 个月前(02月07日) Hmm is anyone else having problems with the pictur...
cuicui 发布于 10 个月前(10月20日) :wink:
niming 发布于 11 个月前(09月19日) 同级校友,能刷到太巧了
davidcheung 发布于 2 年前(08月16日) 我得找一下我之前整理的word文档看一下,如果找到了我就更新一下这篇文章。
Nolan 发布于 2 年前(07月25日) 您的笔记非常有帮助。贴图不显示了,可以更新一下吗?
davidcheung 发布于 3 年前(06月19日) 到没有看webrtc的代码。现在主要在看我们公司的代码了。。。只是偶尔看一看webrtc的东西。。。
aobai 发布于 3 年前(03月13日) gain_change_hangover_ 应该是每三个block 只能够调整一次,这样保证每帧...
匿名 发布于 5 年前(12月30日) 烫
小奥 发布于 5 年前(12月12日) webRTC里面的NS本身我记得就是在C++里面呀

COPYRIGHT © 2025 小奥的学习笔记. ALL RIGHTS RESERVED.

Theme Kratos Made By Seaton Jiang

陕ICP备19003234号-1

鲁公网安备37120202000100号