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

做网站运营有趣吗下载百度

做网站运营有趣吗,下载百度,网页设计与制作课程设计报告,wordpress4.7企业主题Every day a Leetcode 题目来源:2583. 二叉树中的第 K 大层和 解法1:层序遍历 排序 先使用层序遍历计算出树的每一层的节点值的和,保存在数组 levelSum 中。然后将数组进行排序,返回第 k 大的值。需要考虑数组长度小于 k 的边…

Every day a Leetcode

题目来源:2583. 二叉树中的第 K 大层和

解法1:层序遍历 + 排序

先使用层序遍历计算出树的每一层的节点值的和,保存在数组 levelSum 中。然后将数组进行排序,返回第 k 大的值。需要考虑数组长度小于 k 的边界情况。

代码:

/** @lc app=leetcode.cn id=2583 lang=cpp** [2583] 二叉树中的第 K 大层和*/// @lc code=start
/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     TreeNode *left;*     TreeNode *right;*     TreeNode() : val(0), left(nullptr), right(nullptr) {}*     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}*     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}* };*/
class Solution
{
public:long long kthLargestLevelSum(TreeNode *root, int k){if (root == nullptr)return -1;vector<long long> levelSum;queue<TreeNode *> q;q.push(root);while (!q.empty()){int size = q.size();long long sum = 0LL;for (int i = 0; i < size; i++){TreeNode *node = q.front();q.pop();sum += node->val;if (node->left)q.push(node->left);if (node->right)q.push(node->right);}levelSum.push_back(sum);}if (levelSum.size() < k)return -1;sort(levelSum.begin(), levelSum.end());return levelSum[levelSum.size() - k];}
};
// @lc code=end

结果:

在这里插入图片描述

复杂度分析:

时间复杂度:O(nlogn),其中 n 是二叉树的节点个数。

空间复杂度:O(n),其中 n 是二叉树的节点个数。

解法2:层序遍历 + 快速选择

也可以使用快速选择的算法快速定位第 k 大的元素。

代码:

// 层序遍历 + 快速选择class Solution
{
public:long long kthLargestLevelSum(TreeNode *root, int k){if (root == nullptr)return -1;vector<long long> levelSum;queue<TreeNode *> q;q.push(root);while (!q.empty()){int size = q.size();long long sum = 0LL;for (int i = 0; i < size; i++){TreeNode *node = q.front();q.pop();sum += node->val;if (node->left)q.push(node->left);if (node->right)q.push(node->right);}levelSum.push_back(sum);}int n = levelSum.size();if (k > n)return -1;ranges::nth_element(levelSum, levelSum.begin() + (n - k));return levelSum[n - k];}
};

结果:

在这里插入图片描述

复杂度分析:

时间复杂度:O(nlogn),其中 n 是二叉树的节点个数。

空间复杂度:O(n),其中 n 是二叉树的节点个数。

http://www.15wanjia.com/news/5457.html

相关文章:

  • 专业做汽车的网站在哪里找专业推广团队
  • 做新媒体和网站手机优化大师官方版
  • 网站游戏下载推广优化排名
  • 网站建设联网站推广优化网址
  • 建网站推广淘宝店seo推广培训课程
  • 江门网站建设定制免费网站站长查询
  • 中国关于生态文明建设的网站百度热线电话
  • wordpress页面镶入文章志鸿优化网
  • word文档做网站商城小程序开发哪家好
  • 七牛云可以做网站的存储空间吗湖南网站托管
  • 学工业设计出来干什么seo公司优化
  • 苏州前程无忧官上做网站seo刷关键词排名优化
  • 中国战略咨询公司排名天津百度seo推广
  • 优化网站排名怎么制作网站seo基本流程
  • 做动态网站的步骤今天百度数据
  • 音乐网站设计源码百度网页游戏
  • 德州企业做网站多少钱优化网站结构一般包括
  • 镇江网站seo百度搜图
  • 中国住房和城乡建设部网站建造师社群营销的方法和技巧
  • 做网站 框架企业网页设计制作
  • 泉州制作网站开发百度广告搜索引擎
  • WordPress自定义上传目录长沙seo结算
  • vps如何创建网站广州网络营销的推广
  • 小说网站开发背景最近一周新闻
  • 厦门今天刚刚发生的新闻工具站seo
  • 朋友要给我做网站深圳百度百科
  • 网站做链接的意义是什么意思快速seo优化
  • vip影院自助建站系统搜索引擎是软件还是网站
  • 民宿网站开发的开题报告百度推广多少钱一个月
  • 上海发布官网首页seo文章代写平台