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

做网站怎么样百度一下网页搜索

做网站怎么样,百度一下网页搜索,56m做图片视频的网站是什么,可以做视频剪辑兼职的网站目录 530.二叉搜索树的最小绝对差 数组法 双指针法 ⭐ 迭代法 501.二叉搜索树中的众数 双指针法 迭代法 530.二叉搜索树的最小绝对差 题目链接:530. 二叉搜索树的最小绝对差 - 力扣(LeetCode) 文章讲解:代码随想录 数组…

目录

530.二叉搜索树的最小绝对差

数组法

双指针法 ⭐

迭代法

501.二叉搜索树中的众数

双指针法

迭代法


530.二叉搜索树的最小绝对差

  • 题目链接:530. 二叉搜索树的最小绝对差 - 力扣(LeetCode)

  • 文章讲解:代码随想录

数组法
  • 解题思路

    • 把二叉搜索树转换成有序数组,然后遍历一遍数组,就统计出来最小差值了

  • 代码一:数组

class Solution {
private:
vector<int> vec;
void traversal(TreeNode* root) {if (root == NULL) return;traversal(root->left);vec.push_back(root->val); // 将二叉搜索树转换为有序数组traversal(root->right);
}
public:int getMinimumDifference(TreeNode* root) {vec.clear();traversal(root);if (vec.size() < 2) return 0;int result = INT_MAX;for (int i = 1; i < vec.size(); i++) { // 统计有序数组的最小差值result = min(result, vec[i] - vec[i-1]);}return result;}
};
双指针法
  • 解题思路

    • 用一个pre节点记录一下cur节点的前一个节点。在二叉搜素树中序遍历的过程中直接计算。

  • 代码注意

    • 设置函数无返回值,只进行遍历

  • 代码一:双指针

class Solution {
private:
int result = INT_MAX;
TreeNode* pre = NULL;
void traversal(TreeNode* cur) {if (cur == NULL) return;traversal(cur->left);   // 左if (pre != NULL){       // 中result = min(result, cur->val - pre->val);}pre = cur; // 记录前一个traversal(cur->right);  // 右
}
public:int getMinimumDifference(TreeNode* root) {traversal(root);return result;}
};
迭代法
  • 解题思路

    • 用栈模拟中序遍历的迭代法

  • 代码一:中序

class Solution {
public:int getMinimumDifference(TreeNode* root) {stack<TreeNode*> st;TreeNode* cur = root;TreeNode* pre = NULL;int result = INT_MAX;while (cur != NULL || !st.empty()) {if (cur != NULL) { // 指针来访问节点,访问到最底层st.push(cur); // 将访问的节点放进栈cur = cur->left;                // 左} else {cur = st.top();st.pop();if (pre != NULL) {              // 中result = min(result, cur->val - pre->val);}pre = cur;cur = cur->right;               // 右}}return result;}
};

501.二叉搜索树中的众数

  • 题目链接:leetcode.cn

  • 文章讲解:programmercarl.com

双指针法
  • 解题思路

    • 一个指针指向前一个节点,这样每次cur(当前节点)才能和pre(前一个节点)作比较。而且初始化的时候pre = NULL,这样当pre为NULL时候,我们就知道这是比较的第一个元素。

  • 解题步骤

    • 中序遍历:

    • 最大频率统计:

    • 存入众数结果:频率count 等于 maxCount(最大频率),当然要把这个元素加入到结果集中(以下代码为result数组)

    • 结果更新:频率count 大于 maxCount的时候,不仅要更新maxCount,而且要清空结果集(以下代码为result数组),因为结果集之前的元素都失效了。

  • 代码注意

    • if (pre != nullptr && pre->val == cur->val)

  • 代码一:双指针

class Solution {
private:int maxCount = 0; // 最大频率int count = 0; // 统计频率TreeNode* pre = NULL;vector<int> result;void searchBST(TreeNode* cur) {if (cur == NULL) return ;searchBST(cur->left);       // 左// 中if (pre == NULL) { // 第一个节点 //        if (pre != nullptr && pre->val == cur->val) {count = 1;} else if (pre->val == cur->val) { // 与前一个节点数值相同count++;} else { // 与前一个节点数值不同count = 1;}pre = cur; // 更新上一个节点if (count == maxCount) { // 如果和最大值相同,放进result中result.push_back(cur->val);}if (count > maxCount) { // 如果计数大于最大值频率maxCount = count;   // 更新最大频率result.clear();     // 很关键的一步,不要忘记清空result,之前result里的元素都失效了result.push_back(cur->val);}searchBST(cur->right);      // 右return ;}public:vector<int> findMode(TreeNode* root) {count = 0;maxCount = 0;pre = NULL; // 记录前一个节点result.clear();searchBST(root);return result;}
};
迭代法
  • 解题思路

    • 把中序遍历转成迭代,中间节点的处理逻辑完全一样。

  • 代码一:迭代

class Solution {
public:vector<int> findMode(TreeNode* root) {stack<TreeNode*> st;TreeNode* cur = root;TreeNode* pre = NULL;int maxCount = 0; // 最大频率int count = 0; // 统计频率vector<int> result;while (cur != NULL || !st.empty()) {if (cur != NULL) { // 指针来访问节点,访问到最底层st.push(cur); // 将访问的节点放进栈cur = cur->left;                // 左} else {cur = st.top();st.pop();                       // 中if (pre == NULL) { // 第一个节点count = 1;} else if (pre->val == cur->val) { // 与前一个节点数值相同count++;} else { // 与前一个节点数值不同count = 1;}if (count == maxCount) { // 如果和最大值相同,放进result中result.push_back(cur->val);}if (count > maxCount) { // 如果计数大于最大值频率maxCount = count;   // 更新最大频率result.clear();     // 很关键的一步,不要忘记清空result,之前result里的元素都失效了result.push_back(cur->val);}pre = cur;cur = cur->right;               // 右}}return result;}
};

(说明:基于代码随想录课程学习,部分内容引用代码随想录文章)

http://www.tj-hxxt.cn/news/26259.html

相关文章:

  • 做网站约需要多少钱打开百度一下
  • 丰都网站建设深圳排名seo公司
  • 如何给网站做关键字网络营销的基本方式有哪些
  • 服装公司网站源码浏览器里面信息是真是假
  • 网站建设有什么理论依据接app推广
  • wordpress主题英文改中文seo网址大全
  • wordpress自助发货系统优化网站技术
  • 匿名聊天网站开发免费seo营销软件
  • 解析网站制作百度sem推广
  • 无锡崇安网站建设品牌策划方案模板
  • 动态网站建设公司西安网约车
  • 科技小报海东地区谷歌seo网络优化
  • 北京网站开发外包公司济南seo优化外包
  • iis7.0搭建网站seo是付费还是免费推广
  • 重庆网站建设公司是什么意思网络营销推广方案3篇
  • 建设网站的课题营销型网站建设价格
  • 做外贸零售和批发批发网站网店推广方式有哪些
  • 网站制作 流程安卓优化大师下载
  • 哪家公司做网站比较好小学生简短小新闻
  • 爱 做 网站吗如何找外包的销售团队
  • 网站建设服务中心seo美式
  • 免费字体logo设计网络营销优化推广公司
  • 桂林网站建设培训班网络广告营销方案策划内容
  • php框架做网站的好处新闻稿件
  • 浏览器如何做购物网站一键优化下载
  • 自学it从哪里学起优化精灵
  • 做个平台网站怎么做谷歌搜索引擎入口手机版
  • 那曲地区建设局网站百度一下你就知道首页官网
  • 一站式做网站技术2022年搜索引擎优化指南
  • 网站整体地图怎么做郑州seo全网营销